Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Visual Basic [игнор отключен] [закрыт для гостей] / Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!! / 14 сообщений из 14, страница 1 из 1
14.11.2008, 13:20
    #35654224
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
Есть программа на VB для установки двухсторонней печати на принтере.

Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
108.
109.
110.
111.
112.
113.
114.
115.
116.
117.
118.
119.
120.
121.
122.
123.
124.
125.
126.
127.
128.
129.
130.
131.
132.
133.
134.
135.
136.
137.
138.
139.
140.
141.
142.
143.
144.
145.
146.
147.
148.
149.
150.
151.
152.
153.
154.
155.
156.
157.
158.
159.
160.
161.
162.
163.
164.
165.
166.
167.
168.
169.
170.
171.
172.
173.
174.
175.
176.
177.
178.
179.
180.
181.
182.
183.
184.
185.
186.
187.
188.
189.
190.
191.
192.
193.
194.
195.
196.
197.
198.
199.
200.
201.
202.
203.
204.
205.
206.
207.
208.
209.
210.
211.
212.
213.
214.
215.
216.
217.
218.
219.
220.
221.
222.
223.
224.
225.
226.
227.
228.
229.
230.
231.
232.
233.
234.
235.
236.
237.
238.
239.
240.
241.
242.
243.
244.
245.
246.
247.
248.
249.
250.
251.
252.
253.
254.
255.
256.
257.
258.
259.
260.
261.
262.
263.
264.
265.
266.
267.
268.
269.
270.
271.
272.
273.
274.
275.
276.
277.
278.
279.
280.
281.
282.
283.
284.
285.
286.
287.
288.
289.
290.
291.
292.
293.
294.
295.
296.
297.
298.
299.
300.
301.
302.
303.
304.
305.
306.
307.
308.
309.
310.
311.
312.
313.
314.
315.
316.
317.
318.
319.
320.
321.
322.
323.
324.
325.
326.
327.
328.
329.
330.
331.
332.
333.
334.
335.
336.
337.
338.
339.
340.
341.
342.
343.
344.
345.
346.
347.
348.
349.
350.
351.
352.
353.
354.
355.
356.
357.
358.
359.
360.
361.
362.
363.
364.
365.
366.
367.
Option Explicit

Private Type PRINTER_DEFAULTS
   pDatatype As Long
   pDevmode As Long
   DesiredAccess As Long
End Type

Private Type PRINTER_INFO_2
   pServerName As Long
   pPrinterName As Long
   pShareName As Long
   pPortName As Long
   pDriverName As Long
   pComment As Long
   pLocation As Long
   pDevmode As Long               ' Pointer to DEVMODE
   pSepFile As Long
   pPrintProcessor As Long
   pDatatype As Long
   pParameters As Long
   pSecurityDescriptor As Long    ' Pointer to SECURITY_DESCRIPTOR
   Attributes As Long
   Priority As Long
   DefaultPriority As Long
   StartTime As Long
   UntilTime As Long
   Status As Long
   cJobs As Long
   AveragePPM As Long
End Type

Private Type DEVMODE
   dmDeviceName As String *  32 
   dmSpecVersion As Integer
   dmDriverVersion As Integer
   dmSize As Integer
   dmDriverExtra As Integer
   dmFields As Long
   dmOrientation As Integer
   dmPaperSize As Integer
   dmPaperLength As Integer
   dmPaperWidth As Integer
   dmScale As Integer
   dmCopies As Integer
   dmDefaultSource As Integer
   dmPrintQuality As Integer
   dmColor As Integer
   dmDuplex As Integer
   dmYResolution As Integer
   dmTTOption As Integer
   dmCollate As Integer
   dmFormName As String *  32 
   dmUnusedPadding As Integer
   dmBitsPerPel As Integer
   dmPelsWidth As Long
   dmPelsHeight As Long
   dmDisplayFlags As Long
   dmDisplayFrequency As Long
   dmICMMethod As Long
   dmICMIntent As Long
   dmMediaType As Long
   dmDitherType As Long
   dmReserved1 As Long
   dmReserved2 As Long
End Type

Private Const DM_ORIENTATION = &H1
Private Const DM_PAPERSIZE = &H2
Private Const DM_PAPERLENGTH = &H4
Private Const DM_PAPERWIDTH = &H8
Private Const DM_DEFAULTSOURCE = &H200
Private Const DM_PRINTQUALITY = &H400
Private Const DM_COLOR = &H800
Private Const DM_DUPLEX = &H1000

Private Const DM_IN_BUFFER =  8 
Private Const DM_OUT_BUFFER =  2 
Private Const PRINTER_ACCESS_ADMINISTER = &H4
Private Const PRINTER_ACCESS_USE = &H8
Private Const STANDARD_RIGHTS_REQUIRED = &HF0000
Private Const PRINTER_NORMAL_ACCESS = (STANDARD_RIGHTS_REQUIRED Or _
                PRINTER_ACCESS_USE)
  Private Const PRINTER_ALL_ACCESS = (STANDARD_RIGHTS_REQUIRED Or _
             PRINTER_ACCESS_ADMINISTER Or PRINTER_ACCESS_USE)
                
Private Const PRINTER_ENUM_CONNECTIONS = &H4
Private Const PRINTER_ENUM_LOCAL = &H2

Private Declare Function ClosePrinter Lib "winspool.drv" _
      (ByVal hPrinter As Long) As Long
Private Declare Function DocumentProperties Lib "winspool.drv" _
      Alias "DocumentPropertiesA" (ByVal hwnd As Long, _
      ByVal hPrinter As Long, ByVal pDeviceName As String, _
      ByVal pDevModeOutput As Long, ByVal pDevModeInput As Long, _
      ByVal fMode As Long) As Long
Private Declare Function GetPrinter Lib "winspool.drv" Alias _
      "GetPrinterA" (ByVal hPrinter As Long, ByVal Level As Long, _
      pPrinter As Byte, ByVal cbBuf As Long, pcbNeeded As Long) As Long
Private Declare Function OpenPrinter Lib "winspool.drv" Alias _
      "OpenPrinterA" (ByVal pPrinterName As String, phPrinter As Long, _
      pDefault As PRINTER_DEFAULTS) As Long
Private Declare Function SetPrinter Lib "winspool.drv" Alias _
      "SetPrinterA" (ByVal hPrinter As Long, ByVal Level As Long, _
      pPrinter As Byte, ByVal Command As Long) As Long
Private Declare Function EnumPrinters Lib "winspool.drv" _
      Alias "EnumPrintersA" _
      (ByVal flags As Long, ByVal name As String, ByVal Level As Long, _
      pPrinterEnum As Long, ByVal cdBuf As Long, pcbNeeded As Long, _
      pcReturned As Long) As Long

Private Declare Function PtrToStr Lib "kernel32" Alias "lstrcpyA" _
      (ByVal RetVal As String, ByVal Ptr As Long) As Long

Private Declare Function StrLen Lib "kernel32" Alias "lstrlenA" _
      (ByVal Ptr As Long) As Long
Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" _
      (pDest As Any, pSource As Any, ByVal cbLength As Long)
Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)

Private Declare Function DeviceCapabilities Lib "winspool.drv" _
      Alias "DeviceCapabilitiesA" (ByVal lpDeviceName As String, _
      ByVal lpPort As String, ByVal iIndex As Long, lpOutput As Any, _
      ByVal dev As Long) As Long

Public Sub SetColorMode(iColorMode As Long)
   SetPrinterProperty DM_COLOR, iColorMode
End Sub

Public Function GetColorMode() As Long
  GetColorMode = GetPrinterProperty(DM_COLOR)
End Function

Public Sub SetDuplex(iDuplex As Long)
   SetPrinterProperty DM_DUPLEX, iDuplex
End Sub

Public Function GetDuplex() As Long
   GetDuplex = GetPrinterProperty(DM_DUPLEX)
End Function

Public Sub SetPrintQuality(iQuality As Long)
   SetPrinterProperty DM_PRINTQUALITY, iQuality
End Sub

Public Function GetPrintQuality() As Long
   GetPrintQuality = GetPrinterProperty(DM_PRINTQUALITY)
End Function

Private Function SetPrinterProperty(ByVal iPropertyType As Long, _
      ByVal iPropertyValue As Long) As Boolean

   

    Dim hPrinter As Long          'handle for the current printer
    Dim pd As PRINTER_DEFAULTS
    Dim pinfo As PRINTER_INFO_2
    Dim dm As DEVMODE
    Dim sPrinterName As String

    Dim yDevModeData() As Byte        'Byte array to hold contents
                                      'of DEVMODE structure
    Dim yPInfoMemory() As Byte        'Byte array to hold contents
                                      'of PRINTER_INFO_2 structure
    Dim iBytesNeeded As Long
    Dim iRet As Long
    Dim iJunk As Long
    Dim iCount As Long
      
    On Error GoTo cleanup

   
    sPrinterName = "EPSON Stylus Photo R220 Series" 'Имя принтера

    pd.DesiredAccess = PRINTER_ALL_ACCESS 'STANDARD_RIGHTS_REQUIRED 'PRINTER_ACCESS_ADMINISTER 'PRINTER_ACCESS_USE ' PRINTER_ALL_ACCESS 'PRINTER_NORMAL_ACCESS
    iRet = OpenPrinter(sPrinterName, hPrinter, pd)
    If (iRet =  0 ) Or (hPrinter =  0 ) Then
       'Can't access current printer. Bail out doing nothing
       Exit Function
    End If

    'Get the size of the DEVMODE structure to be loaded
    iRet = DocumentProperties( 0 , hPrinter, sPrinterName,  0 ,  0 ,  0 )
    If (iRet <  0 ) Then
       'Can't access printer properties.
       GoTo cleanup
    End If

    'Make sure the byte array is large enough
    'Some printer drivers lie about the size of the DEVMODE structure they
    'return, so an extra 100 bytes is provided just in case!
    ReDim yDevModeData( 0  To iRet +  100 ) As Byte
      
    'Load the byte array
    iRet = DocumentProperties( 0 , hPrinter, sPrinterName, _
                VarPtr(yDevModeData( 0 )),  0 , DM_OUT_BUFFER)
    If (iRet <  0 ) Then
       GoTo cleanup
    End If

    'Copy the byte array into a structure so it can be manipulated
    Call CopyMemory(dm, yDevModeData( 0 ), Len(dm))

    If dm.dmFields And iPropertyType =  0  Then
       'Wanted property not available. Bail out.
       GoTo cleanup
    End If

    'Set the property to the appropriate value
    Select Case iPropertyType
    Case DM_ORIENTATION
       dm.dmOrientation = iPropertyValue
    Case DM_PAPERSIZE
       dm.dmPaperSize = iPropertyValue
    Case DM_PAPERLENGTH
       dm.dmPaperLength = iPropertyValue
    Case DM_PAPERWIDTH
       dm.dmPaperWidth = iPropertyValue
    Case DM_DEFAULTSOURCE
       dm.dmDefaultSource = iPropertyValue
    Case DM_PRINTQUALITY
       dm.dmPrintQuality = iPropertyValue
    Case DM_COLOR
       dm.dmColor = iPropertyValue
    Case DM_DUPLEX
       dm.dmDuplex = iPropertyValue
    End Select
      
    'Load the structure back into the byte array
    Call CopyMemory(yDevModeData( 0 ), dm, Len(dm))

    'Tell the printer about the new property
    iRet = DocumentProperties( 0 , hPrinter, sPrinterName, _
          VarPtr(yDevModeData( 0 )), VarPtr(yDevModeData( 0 )), _
          DM_IN_BUFFER Or DM_OUT_BUFFER)

    If (iRet <  0 ) Then
       GoTo cleanup
    End If

    'The code above *ought* to be sufficient to set the property
    'correctly. Unfortunately some brands of Postscript printer don't
    'seem to respond correctly. The following code is used to make
    'sure they also respond correctly.
    Call GetPrinter(hPrinter,  2 ,  0 ,  0 , iBytesNeeded)
    If (iBytesNeeded =  0 ) Then
       'Couldn't access shared printer settings
       GoTo cleanup
    End If
      
    'Set byte array large enough for PRINTER_INFO_2 structure
    ReDim yPInfoMemory( 0  To iBytesNeeded +  100 ) As Byte

    'Load the PRINTER_INFO_2 structure into byte array
    iRet = GetPrinter(hPrinter,  2 , yPInfoMemory( 0 ), iBytesNeeded, iJunk)
    If (iRet =  0 ) Then
       'Couldn't access shared printer settings
       GoTo cleanup
    End If

    'Copy byte array into the structured type
    Call CopyMemory(pinfo, yPInfoMemory( 0 ), Len(pinfo))

    'Load the DEVMODE structure with byte array containing
    'the new property value
    pinfo.pDevmode = VarPtr(yDevModeData( 0 ))
      
    'Set security descriptor to null
    pinfo.pSecurityDescriptor =  0 
     
    'Copy the PRINTER_INFO_2 structure back into byte array
    Call CopyMemory(yPInfoMemory( 0 ), pinfo, Len(pinfo))

    'Send the new details to the printer
    iRet = SetPrinter(hPrinter,  2 , yPInfoMemory( 0 ),  0 )

    'Indicate whether it all worked or not!
    SetPrinterProperty = CBool(iRet)

cleanup:
   'Release the printer handle
   If (hPrinter <>  0 ) Then Call ClosePrinter(hPrinter)
      
   'Flush the message queue. If you don't do this,
   'you can get page fault errors when you try to
   'print a document immediately after setting a printer property.
   For iCount =  1  To  20 
      DoEvents
   Next iCount
   End Function

Private Function GetPrinterProperty(ByVal iPropertyType As Long) As Long

  

  Dim hPrinter As Long
  Dim pd As PRINTER_DEFAULTS
  Dim dm As DEVMODE
  Dim sPrinterName As String

  Dim yDevModeData() As Byte
  Dim iRet As Long
      
  On Error GoTo cleanup
  
  sPrinterName = "EPSON Stylus Photo R220 Series" 'Имя принтера

  pd.DesiredAccess = PRINTER_ALL_ACCESS 'STANDARD_RIGHTS_REQUIRED 'PRINTER_ACCESS_ADMINISTER 'PRINTER_ACCESS_USE 'PRINTER_ALL_ACCESS 'PRINTER_NORMAL_ACCESS
      
  'Get the printer handle
  iRet = OpenPrinter(sPrinterName, hPrinter, pd)
  If (iRet =  0 ) Or (hPrinter =  0 ) Then
     'Couldn't access the printer
      Exit Function
  End If

  'Find out how many bytes needed for the printer properties
  iRet = DocumentProperties( 0 , hPrinter, sPrinterName,  0 ,  0 ,  0 )
  If (iRet <  0 ) Then
     'Couldn't access printer properties
      GoTo cleanup
  End If

  'Make sure the byte array is large enough, including the
  '100 bytes extra in case the printer driver is lying.
  ReDim yDevModeData( 0  To iRet +  100 ) As Byte
      
  'Load the printer properties into the byte array
  iRet = DocumentProperties( 0 , hPrinter, sPrinterName, _
              VarPtr(yDevModeData( 0 )),  0 , DM_OUT_BUFFER)
  If (iRet <  0 ) Then
     'Couldn't access printer properties
     GoTo cleanup
  End If

  'Copy the byte array to the DEVMODE structure
  Call CopyMemory(dm, yDevModeData( 0 ), Len(dm))

  If Not dm.dmFields And iPropertyType =  0  Then
     'Requested property not available on this printer.
     GoTo cleanup
  End If

  'Get the value of the requested property
  Select Case iPropertyType
  Case DM_ORIENTATION
     GetPrinterProperty = dm.dmOrientation
  Case DM_PAPERSIZE
     GetPrinterProperty = dm.dmPaperSize
  Case DM_PAPERLENGTH
     GetPrinterProperty = dm.dmPaperLength
  Case DM_PAPERWIDTH
     GetPrinterProperty = dm.dmPaperWidth
  Case DM_DEFAULTSOURCE
     GetPrinterProperty = dm.dmDefaultSource
  Case DM_PRINTQUALITY
     GetPrinterProperty = dm.dmPrintQuality
  Case DM_COLOR
     GetPrinterProperty = dm.dmColor
  Case DM_DUPLEX
     GetPrinterProperty = dm.dmDuplex
  End Select
      
cleanup:
   'Release the printer handle
   If (hPrinter <>  0 ) Then Call ClosePrinter(hPrinter)

End Function

как её запустить? установил VB 6.0
Дальше не пойму, что делать?
Вообще задача вызвать как-то программу из WORD'a перед печатью, чтобы печать документа шла на двух сторонах.
Буду признателен за внятные ответы!
...
Рейтинг: 0 / 0
14.11.2008, 13:23
    #35654234
Konst_One
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
это всего лишь код модуля, т.е. из этого еще программу надо делать ;)
...
Рейтинг: 0 / 0
14.11.2008, 13:47
    #35654317
PlanB
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
в worde поставьте "двухстороняя печать" ручками
Как вам ответ?
...
Рейтинг: 0 / 0
14.11.2008, 13:59
    #35654363
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
ручками не пойдёт. я формирую в WORD'вский документ программно их FOX'a и его нужно печатать.
как это сделать???????????????????????????????????????????????
там в примере Epson, у меня HP LaserJet 1320. Наверно, это не критично.
НР поддерживает управление командами, можно вставить в документ ESC-последовательность, будет печатать на двух сторонах, но тут заковыка - если есть колонтитулы, то тогда печатает некорректно, у меня случай с колонтитулами.
...
Рейтинг: 0 / 0
14.11.2008, 17:40
    #35655155
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
Так как сделать программу?
...
Рейтинг: 0 / 0
14.11.2008, 17:49
    #35655184
Konst_One
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
открой vb создай exe-проект для начала, вставь новый модуль, добавь туда код , добавь форму, накидай кнопочки, привяжи к кнопочкам вызовы из модуля, покликай в отладке и тд и тп
...
Рейтинг: 0 / 0
17.11.2008, 12:26
    #35657553
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
Пардон, туплю.
А для чего формочки, кнопочки?
Сама-то программа только вызывается из WORD'a.
Откомпилирую в экзешник. А потом как его вызвать из WORD'a? там же несколько функций: переход в режим двухстороннй печати, потом в односторонний.
или можно без этого?
где-то видел, но не уверен,
в WORD'e пишется
VBA.code
и дальше код на VB.
можно так?
...
Рейтинг: 0 / 0
17.11.2008, 12:35
    #35657586
Konst_One
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
ты хоть exe сделай сначала, может чему научишься. потом уже начнешь делать ActiveX Dll проект, там тебе понадобиться сделать класс , который обернет вызовы из твоего модуля.
...
Рейтинг: 0 / 0
17.11.2008, 16:22
    #35658349
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
дорогой ты мой!
если ты хочешь жрать, так ведь не приходит в голову заняться добычей железной руды, потом построить доменную печь. и всё это для того, чтобы выплавить ложку.
а ты мне предлагаешь что-то вроде этого. я касаюсь VBA в одном моменте, так неужели мне нужно потратить недели, чтобы работать с VBA ?
какое-то детское жлобство.
...
Рейтинг: 0 / 0
17.11.2008, 16:25
    #35658360
Konst_One
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
Полный нольдорогой ты мой!
если ты хочешь жрать, так ведь не приходит в голову заняться добычей железной руды, потом построить доменную печь. и всё это для того, чтобы выплавить ложку.
а ты мне предлагаешь что-то вроде этого. я касаюсь VBA в одном моменте, так неужели мне нужно потратить недели, чтобы работать с VBA ?
какое-то детское жлобство.

я тебе не дорогой, во-первых. а во-вторых, тебе в раздел работа тогда, а здесь люди постигают программирование на VB. никто тут тебе не обязан. и еще, я ведь скорее всего старше тебя, учись уважать других участников форума.
...
Рейтинг: 0 / 0
17.11.2008, 16:26
    #35658362
Игорь Горбонос
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
> Автор: Полный ноль
> дорогой ты мой!

Огласите сумму вознаграждения, и не нужно показывать
> какое-то детское жлобство.

тогда Вам очень быстро предложат несколько вариантов решений.
Но деньги вперёд (с) 12 стульев

--
С уважением Горбонос Игорь Леонидович

Posted via ActualForum NNTP Server 1.4
...
Рейтинг: 0 / 0
17.11.2008, 17:39
    #35658589
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
Уважаемый господин Konst_one!
Примите мои самые искренние извинения!
Видимо, мы просто не поняли друг друга!
Вместе с тем, хотел бы отметить, что обращение на "Вы" должно быть присуще всем участникам форума, а не только зарегистрированным участникам, имхо.
Да, наверно, Вы старше меня. Если Вам более 42-х лет.
Чтобы замять это недоразуменее, замечу, под жлобством понимал высокомерное "может, чему-нибудь научишься" и ответы наотмашь, за что, тем не менее, премного Вам благодарен.
По работе мне хватает заморочек с Oracle и VFP. На VB, к сожалению, времени нет.
...
Рейтинг: 0 / 0
17.11.2008, 17:43
    #35658601
Konst_One
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
если знаете VFP, то проблем вообще не вижу. Среда очень похожа. подсказка в этом посте 6443084
...
Рейтинг: 0 / 0
17.11.2008, 17:45
    #35658608
Konst_One
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!!
что-то ссылку не так вставил ;)
http://www.sql.ru/forum/actualthread.aspx?tid=614284#6448867

1. Word: CreateObject()или через референс -> ActiveXDLL->класс->модуль
2. Word: VBA ->Add Module->код->макрос с вызовом нужной функции
...
Рейтинг: 0 / 0
Форумы / Visual Basic [игнор отключен] [закрыт для гостей] / Помогите запустить программу на VB!!!!!!!!!!!!!!!!!!! / 14 сообщений из 14, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]