VB中打印機(jī)選擇_第1頁
VB中打印機(jī)選擇_第2頁
VB中打印機(jī)選擇_第3頁
VB中打印機(jī)選擇_第4頁
VB中打印機(jī)選擇_第5頁
已閱讀5頁,還剩13頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、(1假設(shè)你的COMMONDIALOG控件叫CMDiag用如下代碼可以使你選擇的打印機(jī)成為默認(rèn)打印機(jī)"Printer"On Error Resume NextCMDiag.PrinterDefault = TrueCMDiag.CancelError = TrueCMDiag.ShowPrinterIf Err.Number <> 0 Then Exit Sub(2VB 里面,原本改變預(yù)設(shè)打印機(jī)的方法是:(假設(shè)安裝有兩種打印機(jī)(驅(qū)動程式Set Printer = Printers(0 ' 將預(yù)設(shè)打印機(jī)設(shè)定成第一種打印機(jī)Set Printer = Print

2、ers(1 ' 將預(yù)設(shè)打印機(jī)設(shè)定成第二種打印機(jī)但實(shí)際上以上敘述有時(shí)候不會成功(原因不詳,為了能夠成功地改變預(yù)設(shè)打印機(jī),以下是呼叫Windows API 的方法:( 此一解決方案適用於Windows 95,981. API 的宣告:Const HWND_BROADCAST = &HFFFF&Const WM_WININICHANGE = &H1APrivate Declare Function GetProfileString Lib "kernel32" Alias _ "GetProfileStringA" (ByVal

3、 lpAppName As String, ByVal lpKeyName As _String, ByVal lpDefault As String, ByVal lpReturnedString As String, _ByVal nSize As Long As LongPrivate Declare Function WriteProfileString Lib "kernel32" Alias _ "WriteProfileStringA" (ByVal lpszSection As String, ByVal lpszKeyName _As

4、String, ByVal lpszString As String As LongPrivate Declare Function SendMessage Lib "user32" Alias "SendMessageA" _(ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, _ lParam As Any As Long2. 程式范例:PrinterName = "您想設(shè)定的打印機(jī)名稱"Dim S As String, length As Long, hKe

5、y As LongS = String(80, Chr(0length = GetProfileString("devices", PrinterName, "", S, Len(SS = Left(S, lengthCall WriteProfileString("windows", "device", PrinterName & "," & SCall SendMessage(HWND_BROADCAST, WM_WININICHANGE, &H7FFF&,

6、ByVal "windows"至於改變NT 預(yù)設(shè)打印機(jī)的方法,則是改變登錄資料庫(Registry打印機(jī)的設(shè)定,在登錄資料庫中紀(jì)錄預(yù)設(shè)打印機(jī)的Value 是:HKEY_CURRENT_USERSoftwareMicrosoftWindowsNTCurrentVersionWindows subkey 的Device value(3VB中獲取指定打印機(jī)的各種紙張類型及大小放入一個(gè)MSFlexGrid,名稱為fgd1,列數(shù)為4'Option ExplicitPrivate Const DC_MAXEXTENT = 5Private Const DC_MINEXTENT

7、= 4Private Const DC_PAPERNAMES = 16Private Const DC_PAPERS = 2Private Const DC_PAPERSIZE = 3Private Declare Function DeviceCapabilities Lib "winspool.drv" Alias "DeviceCap abilitiesA" (ByVal lpDeviceName As String, ByVal lpPort As String, ByVal iIndex As Long, lpOutput As Any, lp

8、DevMode As Any As LongPrivate Type POINTSx As Longy As LongEnd TypePrivate Sub Form_Load(Dim i As LongWith fgd1.Clear.FormatString = "紙張編號|紙張名稱|紙張長度|紙張寬度"For i = 0 To .Cols - 1.ColWidth(i = 1700Next i.AllowUserResizing = flexResizeColumns.Left = 0.Width = Me.ScaleWidthEnd WithGetPaperInfoE

9、nd SubPrivate Sub GetPaperInfo(Dim i As Long, ret As LongDim Length As Integer, Width As IntegerDim PaperNo( As Integer, PaperName( As String, PaperSize( As POINTS'支持最大打印紙:ret = DeviceCapabilities(打印機(jī)名稱, "LPT1", DC_MAXEXTENT, ByVal 0&, ByVal 0& Length = ret 65536Width = ret - L

10、ength * 65536'lblMaxLength.Caption = Length'lblMaxWidth.Caption = Width'支持最小打印紙:ret = DeviceCapabilities(打印機(jī)名稱, "LPT1", DC_MINEXTENT, ByVal 0&, ByVal 0& Length = ret 65536Width = ret - Length * 65536'支持紙張種類數(shù)ret = DeviceCapabilities(打印機(jī)名稱, "LPT1", DC_PAPERS

11、, ByVal 0&, ByVal 0&'紙張編號ReDim PaperNo(1 To ret As IntegerCall DeviceCapabilities(打印機(jī)名稱, "LPT1", DC_PAPERS, PaperNo(1, ByVal 0& '紙張名稱Dim arrPageName( As ByteDim allNames As StringDim lStart As Long, lEnd As LongReDim PaperName(1 To ret As StringReDim arrPageName(1 To re

12、t * 64 As ByteCall DeviceCapabilities(打印機(jī)名稱, "LPT1", DC_PAPERNAMES, arrPageName(1, ByVal 0&allNames = StrConv(arrPageName, vbUnicode'loop through the string and search for the names of the papersi = 1DolEnd = InStr(lStart + 1, allNames, Chr$(0, vbBinaryCompareIf (lEnd > 0 And (l

13、End - lStart - 1 > 0 ThenPaperName(i = Mid$(allNames, lStart + 1, lEnd - lStart - 1i = i + 1End IflStart = lEndLoop Until lEnd = 0'紙張尺寸ReDim PaperSize(1 To ret As POINTSCall DeviceCapabilities(Form2.Combo1.Text, "LPT1", DC_PAPERSIZE, PaperSize(1, ByVal 0&'顯示在表格中For i = 1 To

14、retfgd1.AddItem PaperNo(i & vbTab & PaperName(i & vbTab & PaperSize(i.y & v bTab & PaperSize(i.xNext i'移除第一個(gè)空行fgd1.Row = 1fgd1.RemoveItem 1End SubPrivate Sub Form_Resize(With fgd1.Left = 0.Width = Me.ScaleWidth.Height = Me.ScaleHeight.Top = 0End WithEnd Sub(5編寫VB打印控制程序的幾點(diǎn)

15、心得摘要本文在總結(jié)作者實(shí)際開發(fā)經(jīng)驗(yàn)的基礎(chǔ)上,詳細(xì)介紹了VB實(shí)現(xiàn)高分辨率打印方法的幾點(diǎn)心得。闡述了參數(shù)化繪圖程序縮短打印程序開發(fā)時(shí)間的方法以及打印機(jī)縮放屬性與窗體屬性匹配使用的技巧,并總結(jié)了解決坐標(biāo)定位、圖形與其實(shí)際打印位置出現(xiàn)誤差等問題的經(jīng)驗(yàn)。關(guān)鍵詞 PrintForm 高分辨率打印參數(shù)化繪圖縮放屬性Some Experiences on VB Print ControlBai Yang, Wang PengComputer Science DepartmentUniversity of Information and EngineeringZhengzhou, ChinaAbstract:

16、On the basis of our working experiences, we have 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 on print prog

17、ram 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 attribute1.簡介Visual Basic(VB給用戶提供了可視化編程環(huán)

18、境,因其簡單易學(xué)、功能強(qiáng)大而得到了廣泛的應(yīng)用。VB提供了兩種實(shí)現(xiàn)打印的方法。一般在對打印質(zhì)量要求不高的場合,或者是編程項(xiàng)目的早期開發(fā)過程中,可以直接使用VB窗體的Printform方法實(shí)現(xiàn)打印。用這種方法實(shí)現(xiàn)打印具有編程簡單、易用并且功能強(qiáng)大的優(yōu)點(diǎn),它只需要通過一行代碼,幾乎能打印所有內(nèi)容。實(shí)現(xiàn)的方法就是:首先將要打印的內(nèi)容在屏幕上顯示出來,然后開發(fā)人員只要為窗體對象激活PrintForm ,窗體則自動將要打印的內(nèi)容發(fā)送到Printer對象上,其語法格式如下:窗體.PrintForm。如果窗體中包括圖形,那么打印前應(yīng)先置窗體的AutoRedraw屬性為真。這種方法雖然簡單,但是它卻存在著內(nèi)存消

19、耗大、打印粗糙、速度慢等缺陷,尤其對于帶有滾動條的圖像,這種方法只能打印當(dāng)前可視的區(qū)域。在實(shí)際應(yīng)用中經(jīng)常會遇到對打印質(zhì)量要求很高的場合,例如打印音樂五線譜,對打印的美觀、清晰度以及音符符頭的位置都有很嚴(yán)格的要求,這種應(yīng)用場合若采用VB提供的另一種基于Printer 對象的打印方法則可以獲得高分辨率的打印,得到很高的打印質(zhì)量。在實(shí)際應(yīng)用中,也可以根據(jù)實(shí)際應(yīng)用情況將上述兩種方法結(jié)合起來使用,即:前期工作使用PrintForm 簡單的打印方法將窗體的布局定下來,后期再使用基于Printer對象的打印方法實(shí)現(xiàn)最終的打印工作。2.高分辨率打印程序開發(fā)心得 Printer對象VB的打印可以使用Printe

20、r對象。Printer對象是一個(gè)獨(dú)立于打印機(jī)設(shè)備的封裝,它可以代表不同的打印機(jī),初始時(shí),Printer對象為系統(tǒng)缺省的打印機(jī),也可以使用下列語句: Set Printer=Printers(2 (其中2代表Printers集中的第二個(gè)打印機(jī)對打印機(jī)進(jìn)行指定。Printer對象具備例如:ColorMode、Copies、Duplex、Printquality等控制打印機(jī)特征的屬性,提供了Newpage、EndDoc、KillDoc等控制打印過程的方法,以及大多數(shù)由窗體和圖片框控件提供的圖形屬性和方法如:Currentx、Currenty、Textwidth、Textheight、Print、Ps

21、et、Line、PaintPicture和Circle等方法,它還擁有Font的所有屬性。實(shí)現(xiàn)高分辨率的打印就是通過控制Printer對象的上述屬性和方法完成的。 直接利用Windows公用標(biāo)準(zhǔn)對話框CommonDialog控件【打印】VB為用戶提供了Windows公用標(biāo)準(zhǔn)對話框CommonDialog控件:【打開】、【文件另存為】、【顏色】、【字體】、【打印】。CommonDialog控件在Visual Basic 和Microsoft Windows動態(tài)連接庫Commdlg.dll例程之間提供了接口。利用公用標(biāo)準(zhǔn)對話框【打印】開發(fā)VB的打印程序,將大大縮短程序的開發(fā)周期。應(yīng)用程序中要使用公

22、用對話框,必須首先在工具箱中添加公用對話框控件。該動作通過激活【部件】對話框,選中Microsoft Common Dialog Control6.0, 單擊【確定】即可。然后再將公用控件添加到窗體上并設(shè)置相應(yīng)屬性,該控件具有的屬性有Color、Font、Print、Help等。VB提供mnuFilePrint_Click(過程供用戶添加開發(fā)的打印程序代碼。Printer對象控制打印的基本過程利用Printer對象開發(fā)的打印程序主要靠其提供的NewPage (打印新的一頁,CurrentX、CurrentY置為新頁的左上角,可完成多頁功能。、EndDoc (將打印任務(wù)加入打印機(jī)隊(duì)列、KillD

23、oc (取消打印任務(wù)控制打印過程的。一般情況下,打印程序完成多頁打印時(shí)會多次執(zhí)行NewPage,結(jié)束時(shí)執(zhí)行一次EndDoc將打印任務(wù)加入打印機(jī)隊(duì)列。如果你在NewPage后,立即使用EndDoc,VB則不會打印額外的空白頁。如果希望顯示空白頁,則可在新的一頁上只使用Printer.Print “ “打印空字符即可。為了通過Printer對象實(shí)現(xiàn)文本和圖形的打印,獲得最好的打印質(zhì)量,還需要對VB控制打印機(jī)的多種屬性有更深入的理解,例如打印機(jī)的坐標(biāo)體系向屏幕坐標(biāo)體系的轉(zhuǎn)換、打印機(jī)字體尺寸的確定等。下面給出了打印程序的主框架: Private Sub mnuFilePrint_Click(On Er

24、ror Resume NextIf ActiveForm Is Nothing The n Exit SubWith dlgCommonDialog 打印機(jī)公用對話框.DialogTitle = "打印".CancelError = True.Flags = 1Printer.FontSize = dlgCommonDialog.FontSize將打印機(jī)公用對話框設(shè)置的字體大小傳遞給打印機(jī).ShowPrinter 在屏幕上顯示【打印】公用對話框If Err <> MSComDlg.cdlCancel ThenPrinter.FontTransparent = F

25、alse 初始化打印的字體為不透明SetPrinterScale Myform 匹配打印機(jī)的縮放屬性與窗體的屬性PrintAnywhere Printer 可放置用戶編寫的打印對象參數(shù)化例程實(shí)現(xiàn)字符和圖形的顯示Printer.NewPage 打印機(jī)坐標(biāo)初始化PrintAnywhere Printer 打印另一頁的內(nèi)容Printer.NewPage 打印機(jī)坐標(biāo)初始化 Printer.EndDoc 將該任務(wù)加入打印機(jī)任務(wù)隊(duì)列不打印空白頁P(yáng)rinter.KillDoc 取消當(dāng)前的打印任務(wù)End IfEnd WithEnd Sub參數(shù)化繪圖程序用VB開發(fā)應(yīng)用程序時(shí),如果使用參數(shù)化繪圖例程進(jìn)行屏幕顯示程

26、序的開發(fā),則在開發(fā)打印程序時(shí),就不需再另行開發(fā)代碼,從而避免了大量的重復(fù)勞動,有效地縮短了程序的開發(fā)周期。參數(shù)化繪圖例程就是:在開發(fā)例程時(shí),為每一個(gè)例行程序提供一個(gè)OBJECT類型的參數(shù),調(diào)用程序通過向例程的OBJECT類型參數(shù)分別傳遞窗體、Printer對象,就可分別完成屏幕顯示與打印機(jī)輸出。見如下示例:Sub PrintAnywhere(Dest As ObjectDest.Print “HELLO!”Dest Is Printer The nPrinter.EndDocEnd IfEnd Sub要完成屏幕上的輸出,調(diào)用 PrintAnywhere Myform 即可,而調(diào)用 PrintA

27、nywhere Printer則完成在打印機(jī)上輸出。屬性匹配與窗體縮放因?yàn)榭刂拼蛴C(jī)實(shí)際繪圖區(qū)域大小的屬性Height和Width,由目前正在使用的紙張決定,而且可打印的區(qū)域與紙張邊緣有一定距離。因而為了獲得正確的打印輸出結(jié)果,不能簡單地將Printer對象直接傳遞給繪圖例行程序,還必須要解決打印機(jī)的縮放屬性與顯示窗體屬性相匹配的問題。即:保證使窗體中的打印內(nèi)容以正確的大小顯示,并居于可打印區(qū)域的中間。實(shí)際上實(shí)現(xiàn)的是打印機(jī)的坐標(biāo)體系向屏幕坐標(biāo)體系的轉(zhuǎn)換。具體過程是:使用打印機(jī)的ScaleX和ScaleY方法,獲取以twip為單位的打印機(jī)尺寸,再利用窗體的ScaleX和ScaleY方法將這些尺寸

28、轉(zhuǎn)換為窗體中的坐標(biāo)系統(tǒng),從而實(shí)現(xiàn)以窗體的坐標(biāo)系統(tǒng)提供打印機(jī)可打印區(qū)域大小的目的。然后,用這些尺寸作為打印機(jī)中新的ScaleWidth和ScaleHeight,即可實(shí)現(xiàn)屬性匹配。但是,我們在打印時(shí),經(jīng)常會遇到這樣的場合在不改變窗體形狀的情況下,需要擴(kuò)大或縮小窗體的大小。要完成這樣的工作,不僅需要完成屬性匹配,還要確定對象被縮放的系數(shù)。程序如下:Private Sub SetPrinterScale(obj As ObjectDim pwid As Single, phgt As Single, xmid As Single, ymid As Single Dim owid As Single,

29、ohgt As Singleowid = obj.ScaleX(obj.ScaleWidth, obj.ScaleMode, vbTwipsohgt = obj.ScaleY(obj.ScaleHeight, obj.ScaleMode, vbTwips獲取窗體以Twips表示的尺寸pwid = Printer.ScaleX(Printer.ScaleWidth, Printer.ScaleMode, vbTwipsphgt = Printer.ScaleY(Printer.ScaleHeight, Printer.ScaleMode, vbTwips獲取打印機(jī)以Twips表示的尺寸If (o

30、hgt / owid > phgt / pwid Thens = phgt / ohgtElses = pwid / owidEnd If 計(jì)算縮放因子pwid = obj.ScaleX(pwid, vbTwips, obj.ScaleMode / sphgt = obj.ScaleY(phgt, vbTwips, obj.ScaleMode / s將打印機(jī)的尺寸轉(zhuǎn)換成obj的坐標(biāo)系統(tǒng) / 縮放因子x_mid = obj.ScaleLeft + obj.ScaleWidth / 2y_mid = obj.ScaleTop + obj.ScaleHeight / 2設(shè)置打印區(qū)域的中心點(diǎn)坐標(biāo)

31、Printer.Scale (x_mid - pwid / 2, y_mid - phgt / 2-(x_mid + pwid / 2, y_mid + phgt / 2設(shè)置打印機(jī)中新的ScaleWidth和ScaleHeight End Sub坐標(biāo)定位窗體、圖片框控件以及Printer對象提供的TextWidth和 TextHeight方法在文本定位的應(yīng)用方面很有用。TextWidth、 TextHeight分別以對象當(dāng)前的刻度單位返回字符串的寬度和高度。但是必須注意很多字體中其字符寬度并不全部相同,所以不能簡單地將單個(gè)字符的寬度乘以字符數(shù)來獲得字符串的寬度。對那些沒有TextWidth和T

32、extHeight的控件可通過設(shè)置父窗體的Font屬性,使其與該控件的屬性相匹配,再利用父窗體的TextWidth和TextHeight獲得它的字符串的寬度和高度。但是,我們在完成屏幕顯示程序調(diào)試后,在進(jìn)行打印輸出時(shí)卻出現(xiàn)了屏幕顯示與打印結(jié)果的不一致性的現(xiàn)象,表現(xiàn)在所打印的字體之間坐標(biāo)關(guān)系與屏幕顯示不一樣,例如:屏幕顯示上的兩個(gè)字符不重疊,而打印出的字符卻出現(xiàn)相互重疊的現(xiàn)象。經(jīng)調(diào)試發(fā)現(xiàn),問題出現(xiàn)在字體尺寸的確定上。程序中,屏幕上顯示的字符坐標(biāo)是通過對象的TextWidth和TextHeight方法計(jì)算得來的,它直接受到字體尺寸大小的影響。VB向用戶提供的字體是在用戶需要的打印機(jī)點(diǎn)的范圍內(nèi),如果

33、你需要的字體大小為73點(diǎn),則打印出的實(shí)際字體大小為72.75。然而窗體、圖片框控件的Fontsize只能是整數(shù),例如它不能將字體的大小定為72.75,實(shí)際上這就造成了屏幕上顯示字體與實(shí)際打印字體大小之間產(chǎn)生了誤差。我們采用如下方法來解決該問題,就是在計(jì)算字體大小時(shí),根據(jù)計(jì)算出來的字體尺寸,確定它存在的范圍,然后再將它定位到VB提供的幾種固定大小的字體上,而不是隨意指定。當(dāng)然,也可以有其它的解決辦法。例如:字體大小選取偶數(shù)等。由于篇幅所限,這里不再作介紹。以上是筆者在總結(jié)實(shí)際應(yīng)用工作中的一些心得與體會,希望本篇文章能對首次使用VB開發(fā)打印程序的設(shè)計(jì)人員有所幫助。(6VB中不是有Printers集

34、合嗎寫個(gè)For Each循環(huán)就能枚舉Printers集合中的所有打印機(jī)Printer 對象和Printers 集合使用Printer 對象可以實(shí)現(xiàn)與系統(tǒng)打印機(jī)的通訊(最初是缺省系統(tǒng)打印機(jī)。用Printers 集合可獲取有關(guān)系統(tǒng)上所有可用打印機(jī)的信息。語法PrinterPrinters(indexindex 所在處表示從0 到Printers.Count-1 之間的整數(shù)。說明用圖形方法在Printer 對象上繪制文本和圖形。一旦Printer 對象中含有將要打印的輸出信息,可用EndDoc 方法直接將輸出信息送到應(yīng)用程序的缺省打印機(jī)上。如果要打印這些信息,應(yīng)該檢查和可能還要修正窗體的布局。例如,如果用PrintForm 方法打印窗體,則到頁底圖形圖象可能被剪切,而文本則被移到下一頁。Printers 集合可用來查詢可用的打印機(jī),這

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論