ImageVerifierCode 换一换
格式:DOCX , 页数:10 ,大小:23.65KB ,
资源ID:8202898      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/8202898.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(VB中打印机选择.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

VB中打印机选择.docx

1、VB中打印机选择(1) 假设你的MONDIALOG控件叫CMDiag用如下代码可以使你选择的打印机成为默认打印机PrinterOn Error Resume NextCMDiag.PrinterDefault = TrueCMDiag.CancelError = TrueCMDiag.ShowPrinterIf Err.Number 0 Then Exit Sub(2)VB 里面, 原本改变预设打印机的方法是:(假设安装有两种打印机(驱动程式) Set Printer = Printers(0) 将预设打印机设定成第一种打印机 Set Printer = Printers(1) 将预设打印机设

2、定成第二种打印机 但实际上以上叙述有时候不会成功(原因不详), 为了能够成功地改变预设打印机, 以下是呼叫Windows API 的方法:( 此一解决方案适用於 Windows 95,98) 1. API 的宣告: Const HWND_BROADCAST = &HFFFF& Const WM_WININICHANGE = &H1A Private Declare Function GetProfileString Lib kernel32 Alias _ GetProfileStringA (ByVal lpAppName As String, ByVal lpKeyName As _ St

3、ring, ByVal lpDefault As String, ByVal lpReturnedString As String, _ ByVal nSize As Long) As Long Private Declare Function WriteProfileString Lib kernel32 Alias _ WriteProfileStringA (ByVal lpszSection As String, ByVal lpszKeyName _ As String, ByVal lpszString As String) As Long Private Declare Func

4、tion SendMessage Lib user32 Alias SendMessageA _ (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, _ lParam As Any) As Long 2. 程式范例: PrinterName = 您想设定的打印机名称 Dim S As String, length As Long, hKey As Long S = String(80, Chr(0) length = GetProfileString(devices, PrinterName, , S, Len(S) S

5、 = Left(S, length) Call WriteProfileString(windows, device, PrinterName & , & S) Call SendMessage(HWND_BROADCAST, WM_WININICHANGE, &H7FFF&, ByVal windows) 至於改变 NT 预设打印机的方法, 则是改变登录资料库(Registry)打印机的设定, 在登录资料库中纪录 预设打印机的 Value 是: HKEY_CURRENT_USER SoftwareMicrosoftWindowsNTCurrentVersionWindows subkey 的

6、 Device value (3)VB中获取指定打印机的各种纸张类型及大小放入一个MSFlexGrid,名称为fgd1,列数为4 OptionExplicit PrivateConstDC_MAXEXTENT=5 PrivateConstDC_MINEXTENT=4 PrivateConstDC_PAPERNAMES=16 PrivateConstDC_PAPERS=2 PrivateConstDC_PAPERSIZE=3 PrivateDeclareFunctionDeviceCapabilitiesLibwinspool.drvAliasDeviceCapabilitiesA(ByVall

7、pDeviceNameAsString,ByVallpPortAsString,ByValiIndexAsLong,lpOutputAsAny,lpDevModeAsAny)AsLong PrivateTypePOINTS xAsLong yAsLong EndType PrivateSubForm_Load() DimiAsLong Withfgd1 .Clear .FormatString=纸张编号|纸张名称|纸张长度|纸张宽度 Fori=0To.Cols-1 .ColWidth(i)=1700 Nexti .AllowUserResizing=flexResizeColumns .Lef

8、t=0 .Width=Me.ScaleWidth EndWith GetPaperInfo EndSub PrivateSubGetPaperInfo() DimiAsLong,retAsLong DimLengthAsInteger,WidthAsInteger DimPaperNo()AsInteger,PaperName()AsString,PaperSize()AsPOINTS 支持最大打印纸: ret=DeviceCapabilities(打印机名称,LPT1,DC_MAXEXTENT,ByVal0&,ByVal0&) Length=ret65536 Width=ret-Length

9、*65536 lblMaxLength.Caption=Length lblMaxWidth.Caption=Width 支持最小打印纸: ret=DeviceCapabilities(打印机名称,LPT1,DC_MINEXTENT,ByVal0&,ByVal0&) Length=ret65536 Width=ret-Length*65536 支持纸张种类数 ret=DeviceCapabilities(打印机名称,LPT1,DC_PAPERS,ByVal0&,ByVal0&) 纸张编号 ReDimPaperNo(1Toret)AsInteger CallDeviceCapabilities(

10、打印机名称,LPT1,DC_PAPERS,PaperNo(1),ByVal0&) 纸张名称 DimarrPageName()AsByte DimallNamesAsString DimlStartAsLong,lEndAsLong ReDimPaperName(1Toret)AsString ReDimarrPageName(1Toret*64)AsByte CallDeviceCapabilities(打印机名称,LPT1,DC_PAPERNAMES,arrPageName(1),ByVal0&) allNames=StrConv(arrPageName,vbUnicode) loopthr

11、oughthestringandsearchforthenamesofthepapers i=1 Do lEnd=InStr(lStart+1,allNames,Chr$(0),vbBinarypare) If(lEnd0)And(lEnd-lStart-10)Then PaperName(i)=Mid$(allNames,lStart+1,lEnd-lStart-1) i=i+1 EndIf lStart=lEnd LoopUntillEnd=0 纸张尺寸 ReDimPaperSize(1Toret)AsPOINTS CallDeviceCapabilities(Form2.bo1.Text

12、,LPT1,DC_PAPERSIZE,PaperSize(1),ByVal0&) 显示在表格中 Fori=1Toret fgd1.AddItemPaperNo(i)&vbTab&PaperName(i)&vbTab&PaperSize(i).y&vbTab&PaperSize(i).x Nexti移除第一个空行 fgd1.Row=1 fgd1.RemoveItem1 EndSub PrivateSubForm_Resize() Withfgd1 .Left=0 .Width=Me.ScaleWidth .Height=Me.ScaleHeight .Top=0 EndWith EndSub(5

13、)编写VB打印控制程序的几点心得摘要本文在总结作者实际开发经验的基础上,详细介绍了VB实现高分辨率打印方法的几点心得。阐述了参数化绘图程序缩短打印程序开发时间的方法以及打印机缩放属性与窗体属性匹配使用的技巧,并总结了解决坐标定位、图形与其实际打印位置出现误差等问题的经验。关键词 PrintForm 高分辨率打印 参数化绘图 缩放属性Some Experiences on VB Print Control Bai Yang, Wang Pengputer Science DepartmentUniversity of Information and EngineeringZhengzhou, C

14、hina Abstract: On the basis of our working experiences, wehave given a detail description about VB print method of high resolution. We focus on how to shorten developing period with parameterized plot program, the match between the zoom attribute and the attribute of display window etc., which based

15、 on print program of Printer Object. In addition to this, we have introduced some experiences on dealing with position error that caused by the mismatch between font and graph on screen and that on printer. Keywords: PrintForm, High Resolution Print, parameterized plot ,zoom attribute 1简介Visual Basi

16、c(VB)给用户提供了可视化编程环境,因其简单易学、功能强大而得到了广泛的应用。VB提供了两种实现打印的方法。一般在对打印质量要求不高的场合,或者是编程项目的早期开发过程中,可以直接使用VB窗体的Printform方法实现打印。用这种方法实现打印具有编程简单、易用并且功能强大的优点,它只需要通过一行代码,几乎能打印所有内容。实现的方法就是:首先将要打印的内容在屏幕上显示出来,然后开发人员只要为窗体对象激活 PrintForm ,窗体则自动将要打印的内容发送到Printer对象上,其语法格式如下:窗体.PrintForm 。如果窗体中包括图形,那么打印前应先置窗体的AutoRedraw属性为真。

17、这种方法虽然简单,但是它却存在着内存消耗大、打印粗糙、速度慢等缺陷,尤其对于带有滚动条的图像,这种方法只能打印当前可视的区域。在实际应用中经常会遇到对打印质量要求很高的场合,例如打印音乐五线谱,对打印的美观、清晰度以及音符符头的位置都有很严格的要求,这种应用场合若采用VB提供的另一种基于Printer对象的打印方法则可以获得高分辨率的打印,得到很高的打印质量。在实际应用中,也可以根据实际应用情况将上述两种方法结合起来使用,即:前期工作使用PrintForm 简单的打印方法将窗体的布局定下来,后期再使用基于Printer对象的打印方法实现最终的打印工作。2高分辨率打印程序开发心得 Printer

18、对象VB的打印可以使用Printer对象。Printer对象是一个独立于打印机设备的封装,它可以代表不同的打印机,初始时,Printer对象为系统缺省的打印机,也可以使用下列语句:Set Printer=Printers(2) (其中2代表Printers集中的第二个打印机)对打印机进行指定。Printer对象具备例如:ColorMode、Copies、Duplex、Printquality等控制打印机特征的属性,提供了Newpage、EndDoc、KillDoc等控制打印过程的方法,以及大多数由窗体和图片框控件提供的图形属性和方法如:Currentx、Currenty、Textwidth、T

19、extheight、Print、Pset、Line、PaintPicture和Circle等方法,它还拥有Font的所有属性。实现高分辨率的打印就是通过控制Printer对象的上述属性和方法完成的。 直接利用Windows公用标准对话框monDialog控件【打印】VB为用户提供了Windows公用标准对话框monDialog控件:【打开】、【文件另存为】、【颜色】、【字体】、【打印】。monDialog控件在Visual Basic 和Microsoft Windows动态连接库mdlg.dll例程之间提供了接口。利用公用标准对话框【打印】开发VB的打印程序,将大大缩短程序的开发周期。应用程

20、序中要使用公用对话框,必须首先在工具箱中添加公用对话框控件。该动作通过激活【部件】对话框,选中Microsoft mon Dialog Control6.0, 单击【确定】即可。然后再将公用控件添加到窗体上并设置相应属性,该控件具有的属性有Color、Font、Print、Help等。 VB提供mnuFilePrint_Click()过程供用户添加开发的打印程序代码。 Printer对象控制打印的基本过程利用Printer对象开发的打印程序主要靠其提供的NewPage (打印新的一页,CurrentX、CurrentY置为新页的左上角,可完成多页功能。)、EndDoc (将打印任务加入打印机队

21、列)、KillDoc (取消打印任务)控制打印过程的。一般情况下,打印程序完成多页打印时会多次执行NewPage,结束时执行一次EndDoc将打印任务加入打印机队列。如果你在NewPage后,立即使用EndDoc,VB则不会打印额外的空白页。如果希望显示空白页,则可在新的一页上只使用Printer.Print “ “打印空字符即可。为了通过Printer对象实现文本和图形的打印,获得最好的打印质量,还需要对VB控制打印机的多种属性有更深入的理解,例如打印机的坐标体系向屏幕坐标体系的转换、打印机字体尺寸的确定等。下面给出了打印程序的主框架:Private Sub mnuFilePrint_Cli

22、ck() On Error Resume Next If ActiveForm Is Nothing Then Exit Sub With dlgmonDialog 打印机公用对话框 .DialogTitle = 打印 .CancelError = True .Flags = 1 Printer.FontSize = dlgmonDialog.FontSize 将打印机公用对话框设置的字体大小传递给打印机 .ShowPrinter 在屏幕上显示【打印】公用对话框 If Err MSDlg.cdlCancel Then Printer.FontTransparent = False 初始化打印的

23、字体为不透明 SetPrinterScale Myform 匹配打印机的缩放属性与窗体的属性 PrintAnywhere Printer 可放置用户编写的打印对象参数化例程 实现字符和图形的显示Printer.NewPage 打印机坐标初始化PrintAnywhere Printer 打印另一页的内容Printer.NewPage 打印机坐标初始化 Printer.EndDoc 将该任务加入打印机任务队列 不打印空白页 Printer.KillDoc 取消当前的打印任务 End If End With End Sub 参数化绘图程序用VB开发应用程序时,如果使用参数化绘图例程进行屏幕显示程序的

24、开发,则在开发打印程序时,就不需再另行开发代码,从而避免了大量的重复劳动,有效地缩短了程序的开发周期。参数化绘图例程就是:在开发例程时,为每一个例行程序提供一个OBJECT类型的参数,调用程序通过向例程的OBJECT类型参数分别传递窗体、Printer对象,就可分别完成屏幕显示与打印机输出。 见如下示例:Sub PrintAnywhere(Dest As Object)Dest.Print “HELLO!”Dest Is Printer Then Printer.EndDocEnd IfEnd Sub要完成屏幕上的输出,调用 PrintAnywhere Myform 即可,而调用 PrintA

25、nywhere Printer则完成在打印机上输出。 属性匹配与窗体缩放因为控制打印机实际绘图区域大小的属性Height和Width,由目前正在使用的纸张决定,而且可打印的区域与纸张边缘有一定距离。因而为了获得正确的打印输出结果,不能简单地将Printer对象直接传递给绘图例行程序,还必须要解决打印机的缩放属性与显示窗体属性相匹配的问题。即:保证使窗体中的打印内容以正确的大小显示,并居于可打印区域的中间。实际上实现的是打印机的坐标体系向屏幕坐标体系的转换。具体过程是:使用打印机的ScaleX和ScaleY方法,获取以twip为单位的打印机尺寸,再利用窗体的ScaleX和ScaleY方法将这些尺

26、寸转换为窗体中的坐标系统,从而实现以窗体的坐标系统提供打印机可打印区域大小的目的。然后,用这些尺寸作为打印机中新的ScaleWidth和ScaleHeight,即可实现属性匹配。但是,我们在打印时,经常会遇到这样的场合在不改变窗体形状的情况下,需要扩大或缩小窗体的大小。要完成这样的工作,不仅需要完成属性匹配,还要确定对象被缩放的系数。程序如下:Private Sub SetPrinterScale(obj As Object)Dim pwid As Single, phgt As Single, xmid As Single, ymid As SingleDim owid As Single,

27、 ohgt As Singleowid = obj.ScaleX(obj.ScaleWidth, obj.ScaleMode, vbTwips) ohgt = obj.ScaleY(obj.ScaleHeight, obj.ScaleMode, vbTwips) 获取窗体以Twips表示的尺寸pwid = Printer.ScaleX(Printer.ScaleWidth, Printer.ScaleMode, vbTwips)phgt = Printer.ScaleY(Printer.ScaleHeight, Printer.ScaleMode, vbTwips)获取打印机以Twips表示的

28、尺寸If (ohgt / owid phgt / pwid) Then s = phgt / ohgtElse s = pwid / owidEnd If 计算缩放因子pwid = obj.ScaleX(pwid, vbTwips, obj.ScaleMode) / sphgt = obj.ScaleY(phgt, vbTwips, obj.ScaleMode) / s 将打印机的尺寸转换成obj的坐标系统 / 缩放因子x_mid = obj.ScaleLeft + obj.ScaleWidth / 2y_mid = obj.ScaleTop + obj.ScaleHeight / 2设置打印区域的中心点坐标Printer.Scale (x_mid - pwid / 2, y_mid - phgt / 2)-(x_mid + pwid / 2, y_mid + phgt / 2) 设置打印机中新的ScaleWidth和ScaleHeightEnd Sub 坐标定位 窗体、图片框控件以及Printer对象提供的TextWidth和 Text

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1