Гость
Форумы / Visual Basic [игнор отключен] [закрыт для гостей] / Выяснить сколько доступных для печати принтеров и их марку / 9 сообщений из 9, страница 1 из 1
13.09.2012, 18:45
    #37956660
катастрофа
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Выяснить сколько доступных для печати принтеров и их марку
Здравствуйте, собственно сабж
...
Рейтинг: 0 / 0
13.09.2012, 20:10
    #37956759
Малыхин Сергей
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Выяснить сколько доступных для печати принтеров и их марку
...
Рейтинг: 0 / 0
13.09.2012, 20:16
    #37956762
катастрофа
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Выяснить сколько доступных для печати принтеров и их марку
Малыхин Сергей, xlDialogPrint в переводе для Ворда как будет
я так в той теме не увидел спрашиваемое как получить список принтеров? всё только визуальное восприятие
то есть
ListPrint = ??
...
Рейтинг: 0 / 0
13.09.2012, 20:21
    #37956765
Малыхин Сергей
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Выяснить сколько доступных для печати принтеров и их марку
набери lpstat замечательно список принтеров выыодит
...
Рейтинг: 0 / 0
13.09.2012, 20:32
    #37956775
катастрофа
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Выяснить сколько доступных для печати принтеров и их марку
Малыхин Сергей, где это набирать?
у меня есть форма
______
| | | |
|1|2|3|
|_|_|_|
Это выбираю количество печатаемых копий, печатает на последнем принтере (где была печать последнего дока) вот установил два принтера, нужна возможность выбора с какого печатать
...
Рейтинг: 0 / 0
15.09.2012, 22:45
    #37959010
катастрофа
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Выяснить сколько доступных для печати принтеров и их марку
выяснил
Код: vbnet
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.
Option Explicit
 
Const PRINTER_ENUM_CONNECTIONS = &H4
Const PRINTER_ENUM_LOCAL = &H2
 
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
  
Public Function ListPrinters() As Variant
 
Dim bSuccess As Boolean
Dim iBufferRequired As Long
Dim iBufferSize As Long
Dim iBuffer() As Long
Dim iEntries As Long
Dim iIndex As Long
Dim strPrinterName As String
Dim iDummy As Long
Dim iDriverBuffer() As Long
Dim strPrinters() As String
 
iBufferSize = 3072
 
ReDim iBuffer((iBufferSize \ 4) - 1) As Long
 
'EnumPrinters will return a value False if the buffer is not big enough
bSuccess = EnumPrinters(PRINTER_ENUM_CONNECTIONS Or _
        PRINTER_ENUM_LOCAL, vbNullString, _
        1, iBuffer(0), iBufferSize, iBufferRequired, iEntries)
 
If Not bSuccess Then
    If iBufferRequired > iBufferSize Then
        iBufferSize = iBufferRequired
        Debug.Print "iBuffer too small. Trying again with "; _
        iBufferSize & " bytes."
        ReDim iBuffer(iBufferSize \ 4) As Long
    End If
    'Try again with new buffer
    bSuccess = EnumPrinters(PRINTER_ENUM_CONNECTIONS Or _
            PRINTER_ENUM_LOCAL, vbNullString, _
            1, iBuffer(0), iBufferSize, iBufferRequired, iEntries)
End If
 
If Not bSuccess Then
    'Enumprinters returned False
    MsgBox$ "Error enumerating printers."
    Exit Function
Else
    'Enumprinters returned True, use found printers to fill the array
    ReDim strPrinters(iEntries - 1)
    For iIndex = 0 To iEntries - 1
        'Get the printername
        strPrinterName = Space$(StrLen(iBuffer(iIndex * 4 + 2)))
        iDummy = PtrToStr(strPrinterName, iBuffer(iIndex * 4 + 2))
        strPrinters(iIndex) = strPrinterName
        'Debug.Print strPrinterName
    Next iIndex
End If
 
ListPrinters = strPrinters
MsgBox$ Join(ListPrinters, vbCrLf)
 
End Function
 
Private Sub UserForm_Activate()
 
    Selection.TypeText Text:=Join(ListPrinters, vbCrLf)
    
End Sub


но оставить в списке только те, которые "Готов" в панели управления, можно? как?
...
Рейтинг: 0 / 0
16.09.2012, 14:36
    #37959206
скукотища
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Выяснить сколько доступных для печати принтеров и их марку
> катастрофа
> но оставить в списке только те, которые "Готов" в панели управления, можно? как?

OpenPrinter , GetPrinter , PRINTER_INFO_2 , ClosePrinter

или ( для ленивых )
...
Рейтинг: 0 / 0
16.09.2012, 16:19
    #37959262
катастрофа
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Выяснить сколько доступных для печати принтеров и их марку
скукотища, выбрал для ленивых и застрял на
PrinterName = Printer.DeviceName - ошибка 424 объект регуиред
...
Рейтинг: 0 / 0
20.09.2012, 20:48
    #37966414
скукотища
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Выяснить сколько доступных для печати принтеров и их марку
катастрофа,
комментарии в коде.
...
Рейтинг: 0 / 0
Форумы / Visual Basic [игнор отключен] [закрыт для гостей] / Выяснить сколько доступных для печати принтеров и их марку / 9 сообщений из 9, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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