Español
Fuente/ Codesnippets

Lesezeichen Neigdrehbares

 
Neig/Drehbares Lesezeichen de Andreas Miethe :

Descargar

Andreas Miethe, URL=www.paules-pc-forum.de/forum/XProfan/119302-drehbares-lesezeichen.html#post730089, ZEITPUNKT=13.09.2009
...
KompilierenMarcaSeparación
Drehbares Lesezeichen XProfan 11.2
13.09.2009 - Andreas Miethe
########################################
Bedienung Tastatur :
Pfeil links - Lesezeichen links drehen
Pfeil rechts - Lesezeichen rechts drehen
Pfeil runter - Lesezeichen nach unter
Pfeil hoh - Lesezeichen nach oben
Pos1(HOME) - Lesezeichen gerade richten
Bild runter - Lesezeichen schneller nach unten
Bild hoch - Lesezeichen schneller nach oben
Ende - Lesezeichen mittig ausrichten
Bedienung Maus :
Linke Taste über Lesezeichen gedrückt halten und
Lesezeichen verschieben.
##########################################
 $H Windows.ph
 $H Messages.ph
###############################
Strukturen
###############################
Struct RECT = left&,top&,right&,bottom&
Struct  XFORM =  eM11!,eM12!,eM21!,eM22!,eDx!,eDy!
Hintergrundbild
Var hPic& = Create("hPic",0,"&DSKBMP")
Var XStart& = 0
Var RgnStart& = 0
Var RgnEnd& = 0
Var RgnHeight& = 10
Var IsInvert& = 0
Var Oldmx& = 0
Var Oldmy& = 0
CLS ~GetSysColor(~COLOR_BTNFACE)
~MoveWindow(%hwnd,0,0,%maxx,%maxy,1)
~SetClassLong(%hwnd,~GCL_STYLE,(~GetClassLong(%hwnd,~GCL_STYLE)- ~CS_HREDRAW - ~CS_VREDRAW))
Useicon "A"
SetDialogFont ~GetStockObject(~ANSI_VAR_FONT)
Hintergrundbild anzeigen
DrawSizedPic hPic&,0,0-width(%hwnd),height(%hwnd);0
SubClassing einschalten
###############################
SubClass %HWnd, 1
###############################
Var Button& = Create("Button",%hwnd,"Ende",Width(%hwnd)-120,10,80,24)
Button vom Neuzeichnen ausnehmen, so kann die Region hinter den Button geschoben werden
###############################
Var Rect# = New(RECT)
~GetClientRect(Button&,Rect#)
~MapWindowpoints(Button&,%hwnd,Rect#,2)
~ExcludeClipRect(%hdc,Rect#.left&,Rect#.top&,Rect#.right&,rect#.bottom&)
Dispose rect#
Region erzeugen
Var DC& = ~CreateCompatibleDC(0)
~BeginPath(DC&)
~MoveToEx(DC&,0,RgnStart&,0)
~LineTo(DC&,Width(%hwnd),0)
~LineTo(DC&,Width(%hwnd),RgnHeight&)
~LineTo(DC&,0,RgnStart&+RgnHeight&)
~CloseFigure(DC&)
~EndPath(DC&)
Var hRgn& = ~PathToRegion(DC&)
~DeleteDC(DC&)
DrawRgn(1)

Proc UpdateRgn

    Parameters Richtung&
    Var DC& = ~CreateCompatibleDC(0)

    If Richtung& = 1

        Dec RgnStart&
        Inc RgnEnd&

    Elseif Richtung& = 2

        Inc RgnStart&
        Dec RgnEnd&
        Dec XStart&

    Endif

    ~BeginPath(DC&)

    If Richtung& = 3

        ~Rectangle(DC&,XStart&,RgnStart&,Width(%hwnd),RgnStart&+RgnHeight&)

    Elseif Richtung& = 4

        ~Rectangle(DC&,0,((Height(%hwnd)/2)-(RgnHeight&/2)),Width(%hwnd),((Height(%hwnd)/2)+(RgnHeight&/2)))

    Else

        ~MoveToEx(DC&,XStart&,RgnStart&,0)
        ~LineTo(DC&,Width(%hwnd),RgnEnd&)
        ~LineTo(DC&,Width(%hwnd),RgnEnd&+RgnHeight&)
        ~LineTo(DC&,XStart&,RgnStart&+RgnHeight&)

        If Richtung& = 1

            ~LineTo(DC&,0,RgnEnd&)

        Elseif Richtung& = 2

            ~LineTo(DC&,XStart&,RgnStart&+RgnHeight&)

        Endif

    Endif

    ~EndPath(DC&)
    ~DeleteObject(hRgn&)
    hRgn& = ~PathToRegion(DC&)
    ~DeleteDC(DC&)
    Repaint
    DrawRgn(0)

EndProc

Hautpschleife
#############
Var Ende& = 0

Whilenot Ende&

    Waitinput

    If (%key = 2) Or Clicked(Button&)

        ~DeleteObject(hPic&)
        Ende& = 1

    Endif

EndWhile

SubClassing-Procedur
###############################

SubClassProc

    If SubClassMessage(%hWnd, ~WM_MOUSEMOVE)

        If (~PtInRegion(hRgn&,Loword(&sLParam),HiWord(&sLParam))) And (IsInvert& = 0)

            DrawRgn(0)
            IsInvert& = 1

        ElseIf ((~PtInRegion(hRgn&,Loword(&sLParam),HiWord(&sLParam)))=0) And (IsInvert& = 1)

            DrawRgn(1)
            IsInvert& = 0

        Endif

        If &swParam = ~MK_LBUTTON

            If IsInvert& = 1

                Repaint
                ~OffsetRgn(hRgn&,0,Hiword(&sLParam)-OldmY&)
                DrawRgn(0)
                OldmX& = Loword(&sLParam)
                OldmY& = Hiword(&sLParam)

            Endif

        Endif

    Endif

    If SubClassMessage(%hWnd, ~WM_LBUTTONDOWN)

        If (~PtInRegion(hRgn&,Loword(&sLParam),HiWord(&sLParam))) and (IsInvert& = 1)

            DrawRgn(0)
            OldmX& = Loword(&sLParam)
            OldmY& = Hiword(&sLParam)
            UseCursor 10

        Endif

    Endif

    If SubClassMessage(%hWnd, ~WM_LBUTTONUP)

        If (~PtInRegion(hRgn&,Loword(&sLParam),HiWord(&sLParam))) and (IsInvert& = 1)

            DrawRgn(1)

        Endif

        UseCursor 0
        UpdateRgnBox()

    Endif

    If SubClassMessage(%hWnd, ~WM_KEYDOWN)

        Select &swParam

            Caseof ~VK_DOWN

            Repaint
            ~OffsetRgn(hRgn&,0,4)
            DrawRgn(0)
            UpdateRgnBox()

            Caseof ~VK_UP

            Repaint
            ~OffsetRgn(hRgn&,0,-4)
            DrawRgn(0)
            UpdateRgnBox()

            Caseof ~VK_NEXT

            Repaint
            ~OffsetRgn(hRgn&,0,40)
            DrawRgn(0)
            UpdateRgnBox()

            Caseof ~VK_PRIOR

            Repaint
            ~OffsetRgn(hRgn&,0,-40)
            DrawRgn(0)
            UpdateRgnBox()

            Caseof ~VK_LEFT

            UpdateRgn(2)

            Caseof ~VK_RIGHT

            UpdateRgn(1)

            Caseof ~VK_HOME

            UpdateRgn(3)
            UpdateRgnBox(1)

            Caseof ~VK_END

            UpdateRgn(4)
            UpdateRgnBox()

        Endselect

    Endif

    If SubClassMessage(%hWnd, ~WM_KEYUP)

        Repaint
        DrawRgn(1)

    Endif

EndProc

###############################

Proc UpdateRgnBox

    Var RgnBox# = New(RECT)
    ~GetRgnBox(hRgn&,RgnBox#)

    If &(1)= 1

        RgnStart& = RgnBox#.Top&
        RgnEnd& = RgnBox#.Bottom&+RgnHeight&

    Else

        RgnStart& = RgnBox#.Bottom&-RgnHeight&
        RgnEnd& = RgnBox#.Top&

    Endif

    Dispose RgnBox#

EndProc

Proc DrawRgn

    Parameters F&

    If F& = 1

        UseBrush 1,$8080FF
        ~PaintRgn(%hdc,hRgn&)
        ~FrameRgn(%hdc,hRgn&,~GetStockObject(~BLACK_BRUSH),1,1)

    Else

        UseBrush 1,$FF
        ~PaintRgn(%hdc,hRgn&)
        ~FrameRgn(%hdc,hRgn&,~GetStockObject(~BLACK_BRUSH),1,1)

    Endif

ENDPROC


316 kB
Hochgeladen:27.09.2009
Ladeanzahl96
Descargar
 
23.09.2009  
 



Zum Quelltext


Título del Tema, max. 100 Signo.
 

Systemprofile:

Kein Systemprofil creado. [anlegen]

XProfan:

 Contribución  Font  Smilies  ▼ 

Bitte registro en una Contribución a verfassen.
 

Tema opciones

1.298 Views

Untitledvor 0 min.

Themeninformationen

Dieses Thema ha 1 subscriber:

iF (1x)


Admins  |  AGB  |  Applications  |  Autores  |  Chat  |  Política de Privacidad  |  Descargar  |  Entrance  |  Ayuda  |  Merchantportal  |  Pie de imprenta  |  Mart  |  Interfaces  |  SDK  |  Services  |  Juegos  |  Búsqueda  |  Support

Ein Projekt aller XProfan, el lo son!


Mi XProfan
Privado Noticias
Eigenes Ablageforum
Temas-Merkliste
Eigene Beiträge
Eigene Temas
Zwischenablage
Cancelar
 Deutsch English Français Español Italia
Traducciones

Política de Privacidad


Wir uso Cookies sólo como Session-Cookies wegen el technischen Notwendigkeit y en uns hay no Cookies de Drittanbietern.

Wenn du hier en unsere Webseite klickst oder navigierst, stimmst du unserer Erfassung de Informationen en unseren Cookies en XProfan.Net a.

Weitere Informationen a unseren Cookies y dazu, como du el Kontrolle darüber behältst, findest du en unserer nachfolgenden Datenschutzerklärung.


einverstandenDatenschutzerklärung
Yo möchte no Cookie