Deutsch
Quelltexte/ Codesnippets

Abstand Breite Drucker Einstellungen Höhe Messen Papier Rand Seite - 3

 
Und wer hats erfunden? Natürlich...

Andreas Miethe (17.12.10)

Hier ein alter ( 2000) Code von mir, vielleicht hilft es ja.
KompilierenMarkierenSeparieren
Def @AGetDeviceCaps(2) ! "GDI32","GetDeviceCaps"
Def @ACreateDC(4) ! "GDI32","CreateDCA"
Def @DeleteDC(1) ! "GDI32","DeleteDC"
Declare PDC&,APX!,APY!,PB!,PH!,POX!,POY!,DPIX!,DPIY!,PBMM!,PHMM!,RMM!
Declare PMAX!,PMAY!
Declare drv#,name#,port#
Declare device$,driv$,port$
Declare POR!,PUR!
Declare PLR!,PRR!

Proc GetPrinterDC

    'Printer-DC ermitteln
    DIM drv#,100
    DIM name#,100
    DIM port#,100
    LET device$=@readini$("win.ini","windows","device")
    LET device$=@substr$(@readini$("win.ini","windows","device"),1,",")
    LET driv$= @substr$(@readini$("win.ini","devices",device$),1,",")+".drv"
    LET port$=@substr$(@readini$("win.ini","devices",device$),2,",")
    String name#,0=device$
    String drv#,0=driv$
    String port#,0=port$
    Let PDC&=@ACreateDC(drv#,name#,port#,0)
    dispose drv#
    dispose name#
    dispose port#

EndProc

Proc Werte_Ermitteln

    'Werte ermitteln
    Let APX!=@AGetDeviceCaps(PDC&,8)'Ausgabebreite in Pixel
    Let APY!=@AGetDeviceCaps(PDC&,10)'AusgabeHoehe in Pixel
    Let PB!=@AGetDeviceCaps(PDC&,110)'Physikalische Breite
    Let PH!=@AGetDeviceCaps(PDC&,111)'Physikalische Hoehe
    Let POX!=@AGetDeviceCaps(PDC&,112)'Offset X
    Let POY!=@AGetDeviceCaps(PDC&,113)'Offset Y
    Let DPIX!=@AGetDeviceCaps(PDC&,88)'DPI X
    Let DPIY!=@AGetDeviceCaps(PDC&,90)'DPI Y
    Let PBMM!=@AGetDeviceCaps(PDC&,4)'Ausgabebreite in mm
    Let PHMM!=@AGetDeviceCaps(PDC&,6)'Ausgabehoehe in mm

EndProc

Proc Ausgabe

    'Werte ausgeben
    UseFont "Arial",18,0,1,0,0
    Drawtext 10,0,"Standard-Drucker : "+Device$
    UseFont "Courier New",15,0,0,0,0

    if @AGetDeviceCaps(PDC&,2) = 2

        Drawtext 10,20,"Rasterdrucker"

    endif

    Decimals 0
    Drawtext 10,60,"Ausgabebreite in Pixel         :  "+str$(APX!)
    Drawtext 340,60,"Ausgabehöhe in Pixel         :  "+str$(APY!)
    Drawtext 10,80,"Physikalische Breite in Pixel  :  "+str$(PB!)
    Drawtext 340,80,"Physikalische Höhe in Pixel  :  "+str$(PH!)
    Drawtext 10,100,"Physikalische Offset X         :  "+str$(POX!)
    Drawtext 340,100,"Physikalische Offset Y       :  "+str$(POY!)
    Drawtext 10,120,"Aufloesung Breite (DPI)        :  "+str$(DPIX!)
    Drawtext 340,120,"Aufloesung Höhe (DPI)        :  "+str$(DPIY!)
    Drawtext 10,140,"Ausgabebreite in mm            :  "+str$(PBMM!)
    Drawtext 340,140,"Ausgabebreite in mm          :  "+str$(PHMM!)
    UseFont "Arial",18,0,1,0,1
    DrawText 10,180,"Aus diesen ermittelten Werten lassen sich die Druckränder"
    DrawText 10,200,"für den Standard-Drucker errechnen"
    UseFont "Courier New",15,0,0,0,0
    DrawText 10,240,"Linker Rand in Pixel   :  "+STR$(POX!)
    DrawText 340,240,"Rechter Rand in Pixel  :  "+STR$((PB!-APX!)-POX!)
    DrawText 10,260,"Oberer Rand in Pixel   :  "+STR$(POY!)
    DrawText 340,260,"Unterer Rand in Pixel  :  "+STR$((PH!-APY!)-POY!)
    Decimals 1
    Let PLR!=ROUND((PBMM!/APX!)*POX!,1)
    Let PRR!=ROUND(((PBMM!/APX!)*((PB!-APX!)-POX!)),1)
    Let POR!=ROUND(((PHMM!/APY!)*POY!),1)
    Let PUR!=ROUND(((PHMM!/APY!)*((PH!-APY!)-POY!)),1)
    DrawText 10,280,"Linker Rand in mm      :  "+STR$(PLR!)
    DrawText 340,280,"Rechter Rand in mm     :  "+STR$(PRR!)
    DrawText 10,300,"Oberer Rand in mm      :  "+STR$(POR!)
    DrawText 340,300,"Unterer Rand in mm     :  "+STR$(PUR!)
    Decimals 0
    DrawText 10,340,"Blattgrösse X in mm    :  "+STR$(((PBMM!+PLR!)+PRR!))
    DrawText 340,340,"Blattgrösse Y in mm    :  "+STR$(((PHMM!+POR!)+PUR!))
    Textcolor rgb(255,0,0),rgb(192,192,192)
    UseFont "Courier New",16,0,1,0,0

    If APX! > APY!

        Drawtext 10,40,"Querformat"

    else

        Drawtext 10,40,"Hochformat"

    endif

    Textcolor rgb(255,255,0),rgb(192,192,192)
    UseFont "Arial",14,0,1,0,0
    Drawtext 10,360,"BEACHTE : Die errechneten Werte hängen von der Auflösung und der Papiersorte bzw. Papiergrösse ab, "
    Drawtext 10,380,"die in der Druckereinstellung vorgenommen wurde !"

EndProc

SetTruecolor 1
cls rgb(192,192,192)
Textcolor rgb(0,0,0),rgb(192,192,192)
UseFont "Arial",18,0,1,0,1
UseCursor 2
Drawtext 10,410,"Ermittle Werte für den Standard-Drucker"
GetPrinterDC
Werte_ermitteln
Rectangle 0,8-630,356
Ausgabe
UseFont "Arial",18,0,1,0,1
Textcolor rgb(255,0,0),rgb(192,192,192)
Drawtext 10,410,"Werte für den Standard-Drucker ermittelt"
UseCursor 0
waitinput
@DeleteDC(PDC&)'Printer-DC freigeben
end



 
17.12.2010  
 




Andreas
Miethe


Kleinkram da geht noch viel mehr

Const.ph
KompilierenMarkierenSeparieren
'{ DM-Fields }
DM_ORIENTATION      = 1;
DM_PAPERSIZE        = 2;
DM_PAPERLENGTH      = 4;
DM_PAPERWIDTH       = 8;
DM_SCALE            = $10;
DM_COPIES           = $100;
DM_DEFAULTSOURCE    = $200;
DM_PRINTQUALITY     = $400;
DM_COLOR            = $800;
DM_DUPLEX           = $1000;
DM_YRESOLUTION      = $2000;
DM_TTOPTION         = $4000;
DM_COLLATE          = $8000;
DM_FORMNAME         = $10000;
DM_LOGPIXELS        = $20000;
DM_BITSPERPEL       = $40000;
DM_PELSWIDTH        = $80000;
DM_PELSHEIGHT       = $100000;
DM_DISPLAYFLAGS     = $200000;
DM_DISPLAYFREQUENCY = $400000;
DM_RESERVED1        = $800000;
DM_RESERVED2        = $1000000;
DM_ICMMETHOD        = $2000000;
DM_ICMINTENT        = $4000000;
DM_MEDIATYPE        = $8000000;
DM_DITHERTYPE       = $10000000;
'{ DM-Orientation }
DMORIENT_PORTRAIT  = 1;
DMORIENT_LANDSCAPE = 2;
'{ DM-PrintQualitie }
DMRES_DRAFT   = -1;
DMRES_LOW     = -2;
DMRES_MEDIUM  = -3;
DMRES_HIGH    = -4;
'{ DM-Color }
DMCOLOR_MONOCHROME = 1;
DMCOLOR_COLOR      = 2;
'{ DM-Duplex }
DMDUP_SIMPLEX    = 1;
DMDUP_VERTICAL   = 2;
DMDUP_HORIZONTAL = 3;
'{ DM-TTOptions }
DMTT_BITMAP           = 1;
DMTT_DOWNLOAD         = 2;
DMTT_SUBDEV           = 3;
DMTT_DOWNLOAD_OUTLINE = 4;
'{ DM-Collate }
DMCOLLATE_FALSE = 0;
DMCOLLATE_TRUE = 1;
'{ DM-Media }
DMMEDIA_STANDARD     = 1;
DMMEDIA_TRANSPARENCY = 2;
DMMEDIA_GLOSSY       = 3;
DMMEDIA_USER 	       = $100;

Winspool1.inc
KompilierenMarkierenSeparieren
 $H const.ph
'
'Strukturen
Struct DEVMODE  = DeviceName$(31),dmSpecVersion%,dmDriverVersion%,\
dmSize%,dmDriverExtra%,dmFields&,dmOrientation%,\
dmPaperSize%,dmPaperLength%,dmPaperWidth%,dmScale%,\
dmCopies%,dmDefaultSource%,dmPrintQuality%,dmColor%,\
dmDuplex%,dmYResolution%,dmTTOption%,dmCollate%,\
dmFormName#(4),dmUnusedPadding%,dmBitsPerPel%,\
dmPelsWidth&,dmPelsHeight&,dmDisplayFlags&,\
dmDisplayFrequency&,ExtraData#(2000)
Struct Doc_Info1= Docname#(4),OutFile#(4),Datatype#(4)
Struct Size     = Weite&,Hoehe&
'
'Definitionen
DEF GetNDP_STDPrinter(1) Substr$(ReadIni$("WIN.INI","Windows","Device"),@&(1),",")
DEF @GetSysColor(1) !"USER32","GetSysColor"
DEF DeviceCaps(5) ! "WINSPOOL.DRV","DeviceCapabilitiesA"
DEF OpenPrinter(3) !"WINSPOOL.DRV","OpenPrinterA"
DEF ClosePrinter(1) !"WINSPOOL.DRV","ClosePrinter"
DEF DocumentProperties(6) ! "WINSPOOL.DRV","DocumentPropertiesA"
DEF PrinterProperties(2) ! "WINSPOOL.DRV","PrinterProperties"
DEF SDP(2) ! "GDI32","StartDocA"
DEF EDP(1) ! "GDI32","EndDoc"
DEF SPP(1) ! "GDI32","StartPage"
DEF EPP(1) ! "GDI32","EndPage"
DEF LoadImage(6) !"user32","LoadImageA"
DEF CreateCompatibleDC(1) !"gdi32","CreateCompatibleDC"
DEF SelectObject(2) !"gdi32","SelectObject"
DEF BitBlt(9) !"gdi32","BitBlt"
DEF DeleteObject(1) !"gdi32","DeleteObject"
Def GDIDeviceCaps(2) ! "GDI32","GetDeviceCaps"
DEf LockWindowUpdate(1) ! "USER32","LockWindowUpdate"
DEF GetWindowLong(2) ! "USER32","GetWindowLongA"
DEF SetWindowLong(3) ! "USER32","SetWindowLongA"
DEF GetPrivateProfileSection(4) ! "KERNEL32","GetPrivateProfileSectionA"
DEf CreateDC(4) ! "GDI32","CreateDCA"
DEf DeleteDC(1) ! "GDI32","DeleteDC"
DEf TextOut(5) ! "gdi32","TextOutA"
DEf ExtTextOut(8) ! "gdi32","ExtTextOutA"
DEf GetTextExtentPoint32(4) ! "GDI32","GetTextExtentPoint32A"
DEf SetTextAlign(2) ! "GDI32","SetTextAlign"
DEf SetRect(5) ! "USER32","SetRect"
DEf SetBKMode(2) ! "GDI32","SetBkMode"
'Def DeleteObject(1) ! "GDI32","DeleteObject","%","%"
'Definitionen von Thomas Hoelzer
Def GetStockObject(1) !"GDI32","GetStockObject"
Def SetDefaultGUIFont(1) SendMessage(&(1),$30,Val(GetStockObject($11)),1)
'
'Deklarationen
Declare Printer#,Port#,Driver#,DevmodeInput#,Devmodeoutput#,OutPut#,Selstr#
Declare DocInfo1#
Declare Returnbuffer#
Declare DCArray&,DCSize&,DCExtra&,DCDuplex&,DCCopies&
Declare DCTrueType&,DCBins&,DCPapers&,DCOrientation&
Declare DCBinNames&,DCPaperNames&,DC_DATATYPE_PRODUCED&,DC_FILEDEPENDENCIES&
Declare DC_ENUMRESOLUTIONS&,DC_ENUMRESOLUTIONS1&
Declare DCPapersArray&
Declare DCPaperNamesArray&
Declare MyPrinter&,PrinterFont&
Declare Size#
'Funktionen

PROC TEXTHOEHE

    Parameters DC&
    Declare t$,w&
    Dim size#,Size
    T$ = "A"
    GetTextExtentPoint32(DC&,addr(t$),@Len(T$),size#)
    W& = size#.hoehe&
    Dispose Size#
    Return w&

ENDPROC

'

PROC TEXTWEITE

    Parameters DC&,T$
    Declare t$,w&
    Dim size#,Size
    GetTextExtentPoint32(DC&,addr(t$),@Len(T$),size#)
    W& = size#.Weite&
    Dispose Size#
    Return w&

ENDPROC

'

Proc Printer_Error

    'Fehlermeldung ausgeben
    Parameters Errnum%,D$
    Case Errnum% = 1 : @Messagebox("Kein Standard-Drucker im System installiert","Fehler 1",16)
    Case Errnum% = 2 : @Messagebox("Kein Drucker ausgewählt !","Fehler 2",16)

EndProc

Proc GetPrinterParameter

    'DC-Infos's holen
    'Parameter Listboxhandle
    Parameters LB&
    Declare PName$,PDriver$,PPort$,PDC&
    Declare APX!,APY!,PB!,PH!,POX!,POY!,DPIX!,DPIY!,PBMM!,PHMM!,RMM!
    Declare PMAX!,PMAY!,Tech&
    Declare Rastercaps&,CurveCaps&,LineCaps&,Polygoncaps&,Textcaps&
    Declare POR!,PUR!
    Declare PLR!,PRR!
    PName$   = GetNDP_STDPrinter(1)
    PDriver$ = GetNDP_STDPrinter(3)+".drv"
    PPort$   = GetNDP_STDPrinter(2)
    Let PDC& = CreateDC(addr(pdriver$),addr(Pname$),addr(Pport$),0)
    Tech& = GDIDeviceCaps(PDC&,2)'Technologie
    APX!  = GDIDeviceCaps(PDC&,8)'Ausgabebreite in Pixel
    APY!  = GDIDeviceCaps(PDC&,10)'AusgabeHoehe in Pixel
    PB!   = GDIDeviceCaps(PDC&,110)'Physikalische Breite
    PH!   = GDIDeviceCaps(PDC&,111)'Physikalische Hoehe
    POX!  = GDIDeviceCaps(PDC&,112)'Offset X
    POY!  = GDIDeviceCaps(PDC&,113)'Offset Y
    DPIX! = GDIDeviceCaps(PDC&,88)'DPI X
    DPIY! = GDIDeviceCaps(PDC&,90)'DPI Y
    PBMM! = GDIDeviceCaps(PDC&,4)'Ausgabebreite in mm
    PHMM! = GDIDeviceCaps(PDC&,6)'Ausgabehoehe in mm
    Rastercaps& = GDIDeviceCaps(PDC&,38)'Rastercaps
    Curvecaps&  = GDIDeviceCaps(PDC&,28)'Curvecaps
    Linecaps&   = GDIDeviceCaps(PDC&,20)'Linecaps
    Polygoncaps&   = GDIDeviceCaps(PDC&,32)'Polygoncaps
    Textcaps&   = GDIDeviceCaps(PDC&,34)'Textcaps
    @addstring(LB&,"_____________________________")
    @addstring(LB&,"Drucker-Technologie")
    Case Tech& = 0 : @addstring(LB&,"  - Vector plotter")
    Case Tech& = 1 : @addstring(LB&,"  - Raster display")
    Case Tech& = 2 : @addstring(LB&,"  - Raster printer")
    Case Tech& = 3 : @addstring(LB&,"  - Raster camera")
    Case Tech& = 4 : @addstring(LB&,"  - Character stream")
    Case Tech& = 5 : @addstring(LB&,"  - Metafile")
    Case Tech& = 6 : @addstring(LB&,"  - Display file")
    @addstring(LB&,"_____________________________")
    @addstring(LB&,"Physikalische Druckerwerte : ")
    @addstring(LB&,"Ausgabebreite in Pixel : "+str$(APX!))
    @addstring(LB&,"Ausgabehöhe in Pixel : "+str$(APY!))
    @addstring(LB&,"Physikalische Breite in Pixel : "+str$(PB!))
    @addstring(LB&,"Physikalische Höhe in Pixel  :  "+str$(PH!))
    @addstring(LB&,"Physikalischer Offset X : "+str$(POX!))
    @addstring(LB&,"Physikalischer Offset Y : "+str$(POY!))
    @addstring(LB&,"Aufloesung Breite (DPI) : "+str$(DPIX!))
    @addstring(LB&,"Aufloesung Höhe (DPI) : "+str$(DPIY!))
    @addstring(LB&,"Ausgabebreite in mm : "+str$(PBMM!*10))
    @addstring(LB&,"Ausgabehöhe in mm : "+str$(PHMM!*10))
    @addstring(LB&,"_____________________________")
    @addstring(LB&,"Physikalische Blatt-Grenzen :")
    @addstring(LB&,"Linker Rand in Pixel : "+STR$(POX!))
    @addstring(LB&,"Rechter Rand in Pixel : "+STR$(((PB!-APX!)-POX!)))
    @addstring(LB&,"Oberer Rand in Pixel : "+STR$(POY!))
    @addstring(LB&,"Unterer Rand in Pixel : "+STR$(((PH!-APY!)-POY!)))
    Decimals 1
    PLR!=ROUND(((PBMM!/APX!)*POX!),1)
    PRR!=ROUND(((PBMM!/APX!)*((PB!-APX!)-POX!)),1)
    POR!=ROUND(((PHMM!/APY!)*POY!),1)
    PUR!=ROUND(((PHMM!/APY!)*((PH!-APY!)-POY!)),1)
    @addstring(LB&,"Linker Rand in mm : "+STR$(PLR!))
    @addstring(LB&,"Rechter Rand in mm : "+STR$(PRR!))
    @addstring(LB&,"Oberer Rand in mm : "+STR$(POR!))
    @addstring(LB&,"Unterer Rand in mm : "+STR$(PUR!))
    Decimals 0
    @addstring(LB&,"Blattgrösse X in mm : "+STR$((((PBMM!+PLR!)+PRR!)*10)))
    @addstring(LB&,"Blattgrösse Y in mm : "+STR$((((PHMM!+POR!)+PUR!)*10)))
    @addstring(LB&,"_____________________________")
    @addstring(LB&,"RasterCap - Flags :")
    @addstring(LB&,"Flags : "+Hex$(Rastercaps&))
    Case (Rastercaps& & 1) : @addstring(LB&,"  - Bitblt")
    Case (Rastercaps& & 2) : @addstring(LB&,"  - Banding")
    Case (Rastercaps& & 4) : @addstring(LB&,"  - Skalierung")
    Case (Rastercaps& & 8) : @addstring(LB&,"  - Bitmaps > 64K")
    Case (Rastercaps& & 16) : @addstring(LB&,"  - Windows 2.0 Features")
    Case (Rastercaps& & 32) : @addstring(LB&,"  - GDI20_STATE")
    Case (Rastercaps& & 64) : @addstring(LB&,"  - SAVEBITMAP")
    Case (Rastercaps& & 128) : @addstring(LB&,"  - GetDIBits SetDIBits")
    Case (Rastercaps& & 256) : @addstring(LB&,"  - Paletten-Spezifikation")
    Case (Rastercaps& & 512) : @addstring(LB&,"  - SetDIBitsToDevice")
    Case (Rastercaps& & 1024) : @addstring(LB&,"  - BIGFONT")
    Case (Rastercaps& & 2048) : @addstring(LB&,"  - StretchBlt")
    Case (Rastercaps& & 4096) : @addstring(LB&,"  - Floodfill")
    Case (Rastercaps& & 8192) : @addstring(LB&,"  - StretchDIB")
    Case (Rastercaps& & 16384) : @addstring(LB&,"  - OP_DX_OUTPUT")
    Case (Rastercaps& & 32768) : @addstring(LB&,"  - DevBits")
    @addstring(LB&,"_____________________________")
    @addstring(LB&,"CurveCap - Flags :")
    @addstring(LB&,"Flags : "+hex$(Curvecaps&))
    Case (Curvecaps& & 2) : @addstring(LB&,"  - PIE")
    Case (Curvecaps& & 4) : @addstring(LB&,"  - PREVENTFULLOPEN")
    Case (Curvecaps& & 8) : @addstring(LB&,"  - SHOWHELP")
    Case (Curvecaps& & 16) : @addstring(LB&,"  - WIDE")
    Case (Curvecaps& & 32) : @addstring(LB&,"  - STYLED")
    Case (Curvecaps& & 64) : @addstring(LB&,"  - WIDESTYLED")
    Case (Curvecaps& & 128) : @addstring(LB&,"  - SOLIDCOLOR")
    Case (Curvecaps& & 256) : @addstring(LB&,"  - ROUNDRECT")
    @addstring(LB&,"_____________________________")
    @addstring(LB&,"LineCap - Flags :")
    @addstring(LB&,"Flags : "+hex$(Linecaps&))
    Case (Linecaps& & 2) : @addstring(LB&,"  - POLYLINE")
    Case (Linecaps& & 4) : @addstring(LB&,"  - MARKER")
    Case (Linecaps& & 8) : @addstring(LB&,"  - POLYMARKER")
    Case (Linecaps& & 16) : @addstring(LB&,"  - WIDE")
    Case (Linecaps& & 32) : @addstring(LB&,"  - STYLED")
    Case (Linecaps& & 64) : @addstring(LB&,"  - WIDESTYLED")
    Case (Linecaps& & 128) : @addstring(LB&,"  - INTERIORS")
    @addstring(LB&,"_____________________________")
    @addstring(LB&,"PolygonCap - Flags :")
    @addstring(LB&,"Flags : "+hex$(Polygoncaps&))
    Case (Polygoncaps& & 1) : @addstring(LB&,"  - POLYGON")
    Case (Polygoncaps& & 2) : @addstring(LB&,"  - RECTANGLE")
    Case (Polygoncaps& & 4) : @addstring(LB&,"  - TRAPEZOID")
    Case (Polygoncaps& & 8) : @addstring(LB&,"  - SCANLINE")
    Case (Polygoncaps& & 16) : @addstring(LB&,"  - WIDE")
    Case (Polygoncaps& & 32) : @addstring(LB&,"  - STYLED")
    Case (Polygoncaps& & 64) : @addstring(LB&,"  - WIDESTYLED")
    Case (Polygoncaps& & 128) : @addstring(LB&,"  - INTERIORS")
    Case (Polygoncaps& & 256) : @addstring(LB&,"  - POLYPOLYGON")
    @addstring(LB&,"_____________________________")
    @addstring(LB&,"TextCap - Flags :")
    @addstring(LB&,"Flags : "+hex$(Textcaps&))
    Case (Textcaps& & 1) : @addstring(LB&,"  - OP_CHARACTER")
    Case (Textcaps& & 2) : @addstring(LB&,"  - OP_STROKE")
    Case (Textcaps& & 4) : @addstring(LB&,"  - CP_STROKE")
    Case (Textcaps& & 8) : @addstring(LB&,"  - CR_90")
    Case (Textcaps& & 16) : @addstring(LB&,"  - CR_ANY")
    Case (Textcaps& & 32) : @addstring(LB&,"  - SF_X_YINDEP")
    Case (Textcaps& & 64) : @addstring(LB&,"  - SA_DOUBLE")
    Case (Textcaps& & 128) : @addstring(LB&,"  - SA_INTEGER")
    Case (Textcaps& & 256) : @addstring(LB&,"  - SA_CONTIN")
    Case (Textcaps& & 512) : @addstring(LB&,"  - EA_DOUBLE")
    Case (Textcaps& & 1024) : @addstring(LB&,"  - IA_ABLE")
    Case (Textcaps& & 2048) : @addstring(LB&,"  - UA_ABLE")
    Case (Textcaps& & 4096) : @addstring(LB&,"  - SO_ABLE")
    Case (Textcaps& & 8192) : @addstring(LB&,"  - RA_ABLE")
    Case (Textcaps& & 16384) : @addstring(LB&,"  - VA_ABLE")
    Case (Textcaps& & 32768) : @addstring(LB&,"  - RESERVED")
    Case (Textcaps& & 65536) : @addstring(LB&,"  - SCROLLBLT")
    DeleteDC(PDC&)

EndProc

Proc PrnProp

    'Einrichtungs-Dialog des Druckertreibers
    Declare Ret&
    Dim Printer#,Len(GetNDP_STDPrinter(1))+100
    String Printer#,0=GetNDP_STDPrinter(1)

    If OpenPrinter(Printer#,Addr(MyPrinter&),0)<>0

        Ret& = PrinterProperties(%hwnd,MyPrinter&)
        ClosePrinter(MyPrinter&)

    EndIf

    Dispose Printer#
    Return Ret&

EndProc

'

Proc DocProp

    'Setzen der Druckereinrichtung
    'Parameter : 1 oder 0 für Systemweit oder Programmweit
    Parameters a%
    Declare Ret&
    Dim Printer#,Len(GetNDP_STDPrinter(1))+100
    Dim DevmodeInput#,Devmode
    Dim Devmodeoutput#,Devmode
    string Printer#,0=GetNDP_STDPrinter(1)

    If OpenPrinter(Printer#,Addr(MyPrinter&),0)<>0

        Case (a%=0):Ret& = DocumentProperties(%hwnd,MyPrinter&,Printer#,DevmodeInput#,DevmodeOutput#,12)
        Case (a%=1):Ret& = DocumentProperties(%hwnd,MyPrinter&,Printer#,DevmodeInput#,DevmodeOutput#,13)
        ClosePrinter(MyPrinter&)

    EndIf

    Dispose Printer#
    Dispose DevmodeInput#
    Dispose Devmodeoutput#
    Return Ret&

EndProc

'

Proc GetPrinterCaps

    'allgemeine Druckerwerte holen
    'Parameter : Listboxhandle
    UseCursor 2
    Parameters LB&
    Declare DM$,x%,a%,ax&,ay&
    Clearlist
    Dim Printer#,Len(GetNDP_STDPrinter(1))+100
    Dim Port#,Len(GetNDP_STDPrinter(2))+100
    Dim Output#,$FFFF
    string Printer#,0=GetNDP_STDPrinter(1)
    string Port#,0=GetNDP_STDPrinter(2)
    let DCSize& = DeviceCaps(Printer#,Port#,8,0,0)
    let DCExtra& = DeviceCaps(Printer#,Port#,9,0,0)
    let DCDuplex& = DeviceCaps(Printer#,Port#,7,0,0)
    let DCCopies& = DeviceCaps(Printer#,Port#,18,0,0)
    let DCOrientation& = DeviceCaps(Printer#,Port#,17,0,0)
    let DCBins& = DeviceCaps(Printer#,Port#,6,0,0)
    let DCPapers& = DeviceCaps(Printer#,Port#,2,0,0)
    let DCTrueType& = DeviceCaps(Printer#,Port#,15,0,0)
    Decimals 0
    addstring "Devmode - Strukturgroesse = "+str$(DCSize&+DCExtra&)
    Case DCDuplex& = 1:addstring "Duplex-Printer"
    Casenot DCDuplex& = 1:addstring "Kein Duplex-Printer"
    addstring "Maximale Anzahl der Kopien = "+str$(DCCopies&)
    addstring "Rotation bei Querformat = "+(str$(DCOrientation&)+"°")
    addstring "Einzugsschaechte = ",str$(DCBins&)
    addstring "unterstützte Papierformate = ",str$(DCPapers&)
    DC_ENUMRESOLUTIONS& = DeviceCaps(Printer#,Port#,13,0,0)

    If DC_ENUMRESOLUTIONS& > -1

        addstring "mögliche Auflösungen = "+str$(DC_ENUMRESOLUTIONS&)
        Clear Output#
        x% = 0
        DC_ENUMRESOLUTIONS1& = DeviceCaps(Printer#,Port#,13,Output#,0)

        Whilenot x% = DC_ENUMRESOLUTIONS&*4

            Addstring Str$(Long(Output#,x%))+" X "+Str$(Long(Output#,x%+4))+" DPI"
            x% = x% + 4

        EndWhile

    Endif

    Clear Output#
    let DC_DATATYPE_PRODUCED& = DeviceCaps(Printer#,Port#,21,Output#,0)
    Case DC_DATATYPE_PRODUCED& = -1: addstring "Druckmodus = RAW"
    Clear Output#
    let DC_FILEDEPENDENCIES& = DeviceCaps(Printer#,Port#,21,Output#,0)
    x% = 0
    a% = 0

    If DC_FILEDEPENDENCIES& <> -1

        Whilenot x% = DC_FILEDEPENDENCIES&

            DM$ = string$(Output#,a%)
            addstring "Druckmodus = "+DM$
            inc x%
            a% = a% + 64

        Endwhile

    Endif

    Case DCTrueType& = 1 : addstring "TrueType-Optionen = Bitmap"
    Case DCTrueType& = 2 : addstring "TrueType-Optionen = Download"
    Case DCTrueType& = 8 : addstring "TrueType-Optionen = Download Outline"
    Case DCTrueType& = 3 : addstring "TrueType-Optionen = Substitute"
    Case DCTrueType& = 6 : addstring "TrueType-Optionen = Bitmap,Download,Substitute"
    Case DCTrueType& = 14 : addstring "TrueType-Optionen = Bitmap,Download,Download Outline,Substitute"
    SendMessage(LB&,$0184,0,0)
    Movelisttolist (lb&)
    Dispose Printer#
    Dispose Port#
    Dispose Output#

EndProc

'

Proc PrinterBins

    'Namen der Einzugsschächte holen
    'Parameter : Listboxhandle
    UseCursor 2
    Parameters LB&
    Clearlist
    Declare x%
    Dim Printer#,Len(GetNDP_STDPrinter(1))+100
    Dim Port#,Len(GetNDP_STDPrinter(2))+100
    Dim Output#,$ffff
    string Printer#,0=GetNDP_STDPrinter(1)
    string Port#,0=GetNDP_STDPrinter(2)
    DeviceCaps(Printer#,Port#,12,Output#,0)' DCBinNames

    Whilenot x% = (DCBins&*24)

        addstring String$(Output#,x%)
        x% = x%+24

    EndWhile

    SendMessage(LB&,$0184,0,0)
    Movelisttolist (LB&)
    Dispose Printer#
    Dispose Port#
    Dispose Output#

EndProc

'

Proc PaperNames

    'Namen der unterstützten Papierformate holen
    'Parameter : Listboxhandle
    UseCursor 2
    Parameters LB&
    Clearlist
    Declare x%
    Dim Printer#,Len(GetNDP_STDPrinter(1))+100
    Dim Port#,Len(GetNDP_STDPrinter(2))+100
    Dim Output#,$ffff
    string Printer#,0=GetNDP_STDPrinter(1)
    string Port#,0=GetNDP_STDPrinter(2)
    DeviceCaps(Printer#,Port#,16,Output#,0)' DCPaperNames

    Whilenot x% = (DCPapers&*64)

        addstring String$(Output#,x%)
        x% = x%+64

    EndWhile

    SendMessage(LB&,$0184,0,0)
    Movelisttolist (LB&)
    Dispose Printer#
    Dispose Port#
    Dispose Output#

EndProc

'

Proc PaperFlags

    'Bezeichner für Papierformate holen
    'Parameter : Listboxhandle
    UseCursor 2
    Parameters LB&
    Clearlist
    Declare x%
    Dim Printer#,Len(GetNDP_STDPrinter(1))+100
    Dim Port#,Len(GetNDP_STDPrinter(2))+100
    Dim Output#,$ffff
    string Printer#,0=GetNDP_STDPrinter(1)
    string Port#,0=GetNDP_STDPrinter(2)
    DeviceCaps(Printer#,Port#,2,Output#,0)' DCPapers

    Whilenot x% = (DCPapers&*2)

        addstring str$(word(Output#,x%))
        x% = x%+2

    EndWhile

    SendMessage(LB3&,$0184,0,0)
    Movelisttolist (LB3&)
    Dispose Printer#
    Dispose Port#
    Dispose Output#

EndProc

'

Proc Akt_Printer_Einstellungen

    'aktuelle Druckereinstellung holen
    'Parameter : Listboxhandle
    UseCursor 2
    Parameters LB&,LB2&,LB3&
    Declare Nr&,ST$
    Clearlist
    Dim Printer#,Len(GetNDP_STDPrinter(1))+100
    Dim DevmodeInput#,Devmode
    Dim Devmodeoutput#,Devmode
    Dim Selstr#,200
    string Printer#,0=GetNDP_STDPrinter(1)

    If OpenPrinter(Printer#,Addr(MyPrinter&),0)<>0

        DocumentProperties(%hwnd,MyPrinter&,Printer#,DevmodeInput#,DevmodeOutput#,2)
        ClosePrinter(MyPrinter&)

    EndIf

    Addstring "Druckername : "+DevmodeInput#.Devicename$
    Addstring "Treiber-Version : "+Str$(DevmodeInput#.dmDriverVersion%)
    Addstring "Devmode-Size : "+Str$(DevmodeInput#.dmSize%)
    Addstring "Treiber-Extra-Bytes : "+Str$(DevmodeInput#.dmDriverExtra%)
    Addstring "Devmode-Fields : "+Hex$(DevmodeInput#.dmFields&)
    Case (DevmodeInput#.dmFields& & 1) : Addstring "  - DM_ORIENTATION"
    Case (DevmodeInput#.dmFields& & 2) : Addstring "  - DM_OUT_BUFFER"
    Case (DevmodeInput#.dmFields& & 4) : Addstring "  - DM_PAPERLENGTH"
    Case (DevmodeInput#.dmFields& & 8) : Addstring "  - DM_PAPERWIDTH"
    Case (DevmodeInput#.dmFields& & 16) : Addstring "  - DM_SCALE"
    Case (DevmodeInput#.dmFields& & 256) : Addstring "  - DM_COPIES"
    Case (DevmodeInput#.dmFields& & 512) : Addstring "  - DM_DEFAULTSOURCE"
    Case (DevmodeInput#.dmFields& & 1024) : Addstring "  - DM_PRINTQUALITY"
    Case (DevmodeInput#.dmFields& & 2048) : Addstring "  - DM_COLOR"
    Case (DevmodeInput#.dmFields& & 4096) : Addstring "  - DM_DUPLEX"
    Case (DevmodeInput#.dmFields& & 8192) : Addstring "  - DM_YRESOLUTION"
    Case (DevmodeInput#.dmFields& & 32768) : Addstring "  - DM_COLLATE"
    Case (DevmodeInput#.dmFields& & 65536) : Addstring "  - DM_FORMNAME"
    Case (DevmodeInput#.dmFields& & 131072) : Addstring "  - DM_LOGPIXELS"
    Case (DevmodeInput#.dmFields& & 262144) : Addstring "  - DM_BITSPERPEL"
    Case (DevmodeInput#.dmFields& & 524288) : Addstring "  - DM_PELSWIDTH"
    Case (DevmodeInput#.dmFields& & 1048576) : Addstring "  - DM_PELSHEIGHT"
    Case (DevmodeInput#.dmFields& & 2097152) : Addstring "  - DM_DISPLAYFLAGS"
    Case (DevmodeInput#.dmFields& & 4194304) : Addstring "  - DM_DISPLAYFREQUENCY"
    Case (DevmodeInput#.dmFields& & 33554432) : Addstring "  - DM_ICMMETHOD"
    Case (DevmodeInput#.dmFields& & 67108864) : Addstring "  - DM_ICMINTENT"
    Case (DevmodeInput#.dmFields& & 134217728) : Addstring "  - DM_MEDIATYPE"
    Case (DevmodeInput#.dmFields& & 268435456) : Addstring "  - DM_DITHERTYPE"
    Case DevmodeInput#.dmOrientation%=~DMORIENT_LANDSCAPE:Addstring "Orientierung : Landscape"
    Case DevmodeInput#.dmOrientation%=~DMORIENT_PORTRAIT:Addstring "Orientierung : Portrait"
    St$= str$(DevmodeInput#.dmPaperSize%)
    Nr& = Sendmessage(LB3&,$018F,-1,addr(st$))
    Sendmessage(LB2&,$0189,nr&,Selstr#)
    Addstring "Papierformat : "+string$(Selstr#,0)
    Addstring "Papierlänge : "+str$(DevmodeInput#.dmPaperLength%)+" mm"
    Addstring "Papierbreite : "+str$(DevmodeInput#.dmPaperWidth%)+" mm"
    Addstring "Skalierung : "+str$(DevmodeInput#.dmScale%)+" %"
    Addstring "Kopien : "+str$(DevmodeInput#.dmCopies%)
    St$= str$(DevmodeInput#.dmDefaultSource%)
    Nr& = Sendmessage(LB3&,$018F,-1,addr(st$))
    Sendmessage(LB2&,$0189,nr&,Selstr#)
    Addstring "Default-Source : "+String$(Selstr#,0)
    Case (word(DevmodeInput#,58)=65535):Addstring "Druckqualität : Draft"
    Case (word(DevmodeInput#,58)=65534):Addstring "Druckqualität : Low"
    Case (word(DevmodeInput#,58)=65533):Addstring "Druckqualität : Medium"
    Case (word(DevmodeInput#,58)=65532):Addstring "Druckqualität : High"
    Case (word(DevmodeInput#,58)>65535) Or (word(DevmodeInput#,58)<65532):\
    addstring "Druckqualität : "+str$(word(DevmodeInput#,58))+" DPI"
    Case (DevmodeInput#.dmColor%=~DMCOLOR_COLOR):Addstring "Farbdruck : Farbe"
    Case (DevmodeInput#.dmColor%=~DMCOLOR_MONOCHROME):Addstring "Farbdruck : Graustufen"
    Case (DevmodeInput#.dmDuplex%=~DMDUP_SIMPLEX):Addstring "Duplex : 1-seitig"
    Case (DevmodeInput#.dmDuplex%=~DMDUP_VERTICAL):Addstring "Duplex : 2-seitig-vertikal"
    Case (DevmodeInput#.dmDuplex%=~DMDUP_HORIZONTAL):Addstring "Duplex : 2-seitig-horizontal"
    Addstring "Y-Auflösung : "+str$(DevmodeInput#.dmYResolution%)
    Case (DevmodeInput#.dmTTOption%=~DMTT_BITMAP):Addstring "Truetype als : Bitmap"
    Case (DevmodeInput#.dmTTOption%=~DMTT_DOWNLOAD):Addstring "Truetype als : Download"
    Case (DevmodeInput#.dmTTOption%=~DMTT_SUBDEV):Addstring "Truetype als : Ersatz"
    Case (DevmodeInput#.dmTTOption%=~DMTT_DOWNLOAD_OUTLINE):Addstring "Truetype als : Download-Outline"
    Case (DevmodeInput#.dmCollate%=~DMCOLLATE_FALSE):Addstring "Collate : Nein"
    Case (DevmodeInput#.dmCollate%=~DMCOLLATE_TRUE):Addstring "Collate : Ja"
    Case (word(DevmodeInput#,132)=~DMMEDIA_STANDARD):Addstring "Druckermedium : Normalpapier"
    Case (word(DevmodeInput#,132)=~DMMEDIA_GLOSSY):Addstring "Druckermedium : Glossy"
    Case (word(DevmodeInput#,132)=~DMMEDIA_TRANSPARENCY):Addstring "Druckermedium : Transparent"
    Case (word(DevmodeInput#,132)=~DMMEDIA_USER):Addstring "Druckermedium : Benutzerdefiniert"
    SendMessage(LB&,$0184,0,0)
    Movelisttolist (LB&)
    Dispose DevmodeInput#
    Dispose DevmodeOutput#
    Dispose Printer#
    Dispose Selstr#

EndProc

'

Proc GetPrinters

    'Drucker im System ermitteln
    'Parameter : Listboxhandle
    Parameters LB&
    Clearlist
    Declare Section_name$,ReturnSize&,IniFile$,Returnname$,x%
    Declare PName$,PDriver$,PPort$
    Section_name$ = "DEVICES"
    IniFile$      = "Win.ini"
    Returnsize&   = 32767
    Dim ReturnBuffer#,Returnsize&
    GetPrivateProfileSection(ADDR(Section_name$),ReturnBuffer#,ReturnSize&,ADDR(IniFile$))

    Whilenot x% = Returnsize&

        Returnname$ = String$(ReturnBuffer#,x%)
        Case returnname$ = "": Break
        Pname$   = Substr$(Returnname$,1,"=")'Name
        PDriver$ = Substr$(Substr$(Returnname$,1,","),2,"=")'Treiber
        PPort$   = Substr$(Substr$(Returnname$,2,","),1,"=")'Port
        AddString PName$+","+PDriver$+","+PPort$
        X% = X% + Len(Returnname$) +1

    Endwhile

    SendMessage(LB&,$0184,0,0)
    Movelisttolist (LB&)
    Dispose Returnbuffer#

EndProc

'

Proc ChangeStandardPrinter

    'Standard-Drucker wechseln
    Parameters F$
    Declare IniFile$
    IniFile$      = "Win.ini"
    WRITEINI "Win.Ini","Windows","Device"=F$
    SendMessage($FFFF,$001A,0,ADDR(IniFile$))'Win-Ini-Update

EndProc


Programm
KompilierenMarkierenSeparieren
'#########################################
'Drucker-Einstellungen holen und setzen
'ab Win 9.X und Profan 7.X
'Andreas Miethe * Dezember 2000
'#########################################
'
'
 $I Winspool1.inc
'
Declare TTT&,LB&,LB1&,LB2&,LB3&,LB4&,LB5&
Declare Ende%,GetP&,SetP&,Config&,Config1&,GoOut&
Declare Picture$
'
settruecolor 1
WindowTitle "Druckereinstellungen......"
Window %maxx+1,0-640,480
cls @GetSysColor(15)
UseIcon "DRUCKER"
Usefont "MS Sans Serif",14,0,0,0,0
SetDialogfont 1

Proc Fensteraufbau

    TTT& = Createtext(%hwnd,"",12,0,600,14)
    Createtext(%hwnd,"Allgemeine Infos",12,14,300,24)
    Let LB& = CreateListbox(%hwnd,"",0,0,0,0)
    SetDefaultGUIFont(LB&)
    Createtext(%hwnd,"Druckerschächte",12,114,300,14)
    Let LB1& = CreateListbox(%hwnd,"",0,0,0,0)
    SetDefaultGUIFont(LB1&)
    Createtext(%hwnd,"unterstützte Papierformate",12,214,300,14)
    Let LB2& = CreateListbox(%hwnd,"",0,0,0,0)
    SetDefaultGUIFont(LB2&)
    Createtext(%hwnd,"Installierte Drucker",12,315,300,14)
    Let LB5& = CreateListbox(%hwnd,"",0,0,0,0)
    SetDefaultGUIFont(LB5&)
    Createtext(%hwnd,"Format-NR.",322,214,90,14)
    Let LB3& = CreateListbox(%hwnd,"",0,0,0,0)
    SetDefaultGUIFont(LB3&)
    Createtext(%hwnd,"aktuelle Einstellungen, Werte und Möglichkeiten",322,14,320,14)
    Let LB4& = CreateListbox(%hwnd,"",0,0,0,0)
    SetDefaultGUIFont(LB3&)
    Let SetP& = CreateButton(%hwnd,"Standard-Drucker wechseln",320,405,220,20)
    SetDefaultGUIFont(SetP&)
    Let Config& = CreateButton(%hwnd,"Drucker einrichten",320,355,220,20)
    SetDefaultGUIFont(Config&)
    Let Config1& = CreateButton(%hwnd,"Drucker - Eigenschaften",320,380,220,20)
    SetDefaultGUIFont(Config&)
    Let GoOut& = CreateButton(%hwnd,"Ende",440,260,80,20)
    SetDefaultGUIFont(GoOut&)
    @Control("Static","Drucker",$50000003,580,390,0,0,%hwnd,0,%Hinstance,0)
    Settext TTT&,"Drucker : "+GetNDP_STDPrinter(1)+" an : "+GetNDP_STDPrinter(3)
    SetWindowlong(LB&,-16,GetWindowlong(LB1&,-16) | ,$50200000)
    SetWindowlong(LB1&,-16,GetWindowlong(LB1&,-16) | $50200000)
    SetWindowlong(LB2&,-16,GetWindowlong(LB1&,-16) | $50200000)
    SetWindowlong(LB3&,-16,GetWindowlong(LB1&,-16) | $50200000)
    SetWindowlong(LB4&,-16,GetWindowlong(LB1&,-16) | $50200000)
    SetWindowlong(LB5&,-16,GetWindowlong(LB1&,-16) | ,$50200000)
    Setwindowpos LB& = 10,30-300,80
    Setwindowpos LB1& = 10,130-300,80
    Setwindowpos LB2& = 10,230-300,80
    Setwindowpos LB3& = 320,230-100,80
    Setwindowpos LB4& = 320,30-300,180
    Setwindowpos LB5& = 10,335-300,90

EndProc

Proc GetInfo

    Declare msg&,msgt&

    If GetNDP_STDPrinter(1) <> ""

        UseCursor 2
        LockWindowUpdate(%hwnd)
        msg& = CreateDialog(%hwnd,"Moment bitte...",(%maxx+1),0,0,0)
        msgt& = Createtext(msg&,"ermittle Werte..........",20,2,180,20)
        Setwindowlong(msg&,-16,$50C00000)
        Setwindowlong(msg&,-20,$50000280)
        Setwindowpos msg& = (Width(%Desktop)/2-100) ,(Height(%desktop)/2-22) - 200,45
        Settext TTT&,"Drucker : "+GetNDP_STDPrinter(1)+" an : "+GetNDP_STDPrinter(3)
        GetPrinters LB5&
        GetPrinterCaps LB&
        PrinterBins LB1&
        PaperNames LB2&
        PaperFlags LB3&
        Akt_Printer_Einstellungen LB4&,LB2&,LB3&
        GetPrinterParameter LB4&
        Destroywindow(msg&)
        LockWindowUpdate(0)
        UseCursor 0

    else

        Printer_Error 1

    Endif

EndProc

Fensteraufbau
setwindowpos %hwnd = (Width(%Desktop)/2-320) ,(Height(%desktop)/2-240) - 640,480
GetPrinters LB5&
GetInfo
SetFocus(%hwnd)

Whilenot ende%

    waitinput

    If GetFocus(GetP&)

        PrintPrinter LB4&
        setFocus(%hwnd)

    Elseif GetFocus(SetP&)

        If @getCursel(LB5&) > -1

            ChangeStandardPrinter Getstring$(LB5&,@GetCursel(LB5&))
            Settext TTT&,"Drucker : "+GetNDP_STDPrinter(1)+" an : "+GetNDP_STDPrinter(3)
            GetInfo
            setFocus(%hwnd)

        else

            Printer_Error 2

        Endif

    Elseif GetFocus(Config&)

        If GetNDP_STDPrinter(1) <> ""

            DocProp 1
            Case @&(0) = 1: GetInfo
            setFocus(%hwnd)

        else

            Printer_Error 1

        Endif

    Elseif GetFocus(Config1&)

        If GetNDP_STDPrinter(1) <> ""

            PrnProp
            Case @&(0) = 1: GetInfo
            setFocus(%hwnd)

        else

            Printer_Error 1

        Endif

    Elseif GetFocus(GoOut&)

        Let Ende% = 1

    Endif

EndWhile

End
 
Gruss
Andreas
________ ________ ________ ________ _
Profan 3.3 - XProfanX2
Win 95,98,ME,2000,XP,Vista - Win 7 32 / 64 Bit
ASUS X93S - Intel Core I7-NVIDIA GForce 540M 8GB Arbeitsspeicher
Homepage :  [...] 
17.12.2010  
 



Gewaltig ^^ !

Ein kleiner Bug aber lässts abstürzen - in der WinSpool1.inc Funktion Akt_Printer_Einstellungen ganz unten muss ich Dispose DevmodeOutput# ausklammern da ich sonst einen Absturz erhalte:
KompilierenMarkierenSeparieren
Dispose DevmodeInput#
messagebox "","",0
'Dispose DevmodeOutput#
messagebox "","",0
Dispose Printer#

(habe mich mit MessageBoxen hingekämpft... ^^)

Ich sehe auf Anhieb nicht warum das der Fall ist - ansonsten läuft es tadellos durch und zeigt all diese lecker Eigenschaften...:


22 kB
Hochgeladen:17.12.2010
Ladeanzahl176
Herunterladen
 
17.12.2010  
 



Zum Quelltext


Thementitel, max. 100 Zeichen.
 

Systemprofile:

Kein Systemprofil angelegt. [anlegen]

XProfan:

 Beitrag  Schrift  Smilies  ▼ 

Bitte anmelden um einen Beitrag zu verfassen.
 

Themenoptionen

6.445 Betrachtungen

Unbenanntvor 0 min.
Sven Bader11.07.2021
rquindt28.11.2017
GDL26.03.2016
Manfred Barei26.07.2015
Mehr...

Themeninformationen

Dieses Thema hat 2 Teilnehmer:

iF (2x)
Andreas Miethe (1x)


Admins  |  AGB  |  Anwendungen  |  Autoren  |  Chat  |  Datenschutz  |  Download  |  Eingangshalle  |  Hilfe  |  Händlerportal  |  Impressum  |  Mart  |  Schnittstellen  |  SDK  |  Services  |  Spiele  |  Suche  |  Support

Ein Projekt aller XProfaner, die es gibt!


Mein XProfan
Private Nachrichten
Eigenes Ablageforum
Themen-Merkliste
Eigene Beiträge
Eigene Themen
Zwischenablage
Abmelden
 Deutsch English Français Español Italia
Übersetzungen

Datenschutz


Wir verwenden Cookies nur als Session-Cookies wegen der technischen Notwendigkeit und bei uns gibt es keine Cookies von Drittanbietern.

Wenn du hier auf unsere Webseite klickst oder navigierst, stimmst du unserer Erfassung von Informationen in unseren Cookies auf XProfan.Net zu.

Weitere Informationen zu unseren Cookies und dazu, wie du die Kontrolle darüber behältst, findest du in unserer nachfolgenden Datenschutzerklärung.


einverstandenDatenschutzerklärung
Ich möchte keinen Cookie