Deutsch
Quelltexte/ Codesnippets

Lesezeichen Neigdrehbares

 
Neig/Drehbares Lesezeichen von Andreas Miethe :

Download

Andreas Miethe, URL=www.paules-pc-forum.de/forum/xprofan/119302-drehbares-lesezeichen.html#post730089, ZEITPUNKT=13.09.2009
...
KompilierenMarkierenSeparieren
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
Herunterladen
 
23.09.2009  
 



Zum Quelltext


Thementitel, max. 100 Zeichen.
 

Systemprofile:

Kein Systemprofil angelegt. [anlegen]

XProfan:

 Beitrag  Schrift  Smilies  ▼ 

Bitte anmelden um einen Beitrag zu verfassen.
 

Themenoptionen

1.286 Betrachtungen

Unbenanntvor 0 min.

Themeninformationen

Dieses Thema hat 1 Teilnehmer:

iF (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