Browse Source

Gestrichelte rahmen hinzugefügt

Kolja Strohm 6 years ago
parent
commit
44b59a6957
2 changed files with 119 additions and 23 deletions
  1. 113 23
      Rahmen.cpp
  2. 6 0
      Rahmen.h

+ 113 - 23
Rahmen.cpp

@@ -13,7 +13,8 @@ Rahmen::Rahmen()
     : Zeichnung(),
     : Zeichnung(),
     br( 1 ),
     br( 1 ),
     farbe( 0xFF000000 ),
     farbe( 0xFF000000 ),
-    alpha( 0 )
+    alpha( 0 ),
+    breaks( 0 )
 {}
 {}
 
 
 // Destruktor
 // Destruktor
@@ -27,6 +28,13 @@ void Rahmen::setRamenBreite( int br ) // setzt die Breite des Rahmens
     rend = 1;
     rend = 1;
 }
 }
 
 
+// wenn dieser Flag gesetzt wird, wird der Rahmen gestrichelt gezeichnet
+//  br: 1 -> gestrichelt, 0 -> durchgehend
+void Rahmen::setBreaks( bool br )
+{
+    breaks = br;
+}
+
 void Rahmen::setAlpha( bool a ) // Legt fest, ob der Alphawert der Farbe berücksichtigt werden soll
 void Rahmen::setAlpha( bool a ) // Legt fest, ob der Alphawert der Farbe berücksichtigt werden soll
 {
 {
     alpha = a;
     alpha = a;
@@ -54,6 +62,12 @@ int Rahmen::getRBreite() const // Gibt die Breite des Rahmens zur
     return br;
     return br;
 }
 }
 
 
+// Gibt 1 zurück, falls der Rahmen gestrichelt gezeichnet wird
+bool Rahmen::hasBreaks() const
+{
+    return breaks;
+}
+
 
 
 // Inhalt der LRahmen Klasse aus Rahmen.h
 // Inhalt der LRahmen Klasse aus Rahmen.h
 // Konstruktor 
 // Konstruktor 
@@ -72,24 +86,62 @@ void LRahmen::render( Bild &Obj ) // Zeichnet den Rahmen in das RenderZeichnung
     int y = pos.y;
     int y = pos.y;
     int b = x + gr.x - 1;
     int b = x + gr.x - 1;
     int h = y + gr.y - 1;
     int h = y + gr.y - 1;
-    if( alpha )
+    if( !breaks )
     {
     {
-        for( int i = 0; i < br; ++i )
+        if( alpha )
+        {
+            for( int i = 0; i < br; ++i )
+            {
+                Obj.drawLinieHAlpha( x + i + 1, y + i, gr.x - i * 2 - 1, farbe );
+                Obj.drawLinieVAlpha( b - i, y + i + 1, gr.y - i * 2 - 2, farbe );
+                Obj.drawLinieHAlpha( x + i + 1, h - i, gr.x - i * 2 - 1, farbe );
+                Obj.drawLinieVAlpha( x + i, y + i, gr.y - i * 2, farbe );
+            }
+        }
+        else
         {
         {
-            Obj.drawLinieHAlpha( x + i + 1, y + i, gr.x - i * 2 - 1, farbe );
-            Obj.drawLinieVAlpha( b - i, y + i + 1, gr.y - i * 2 - 2, farbe );
-            Obj.drawLinieHAlpha( x + i + 1, h - i, gr.x - i * 2 - 1, farbe );
-            Obj.drawLinieVAlpha( x + i, y + i, gr.y - i * 2, farbe );
+            for( int i = 0; i < br; ++i )
+            {
+                Obj.drawLinieH( x + i + 1, y + i, gr.x - i * 2 - 1, farbe );
+                Obj.drawLinieV( b - i, y + i + 1, gr.y - i * 2 - 2, farbe );
+                Obj.drawLinieH( x + i + 1, h - i, gr.x - i * 2 - 1, farbe );
+                Obj.drawLinieV( x + i, y + i, gr.y - i * 2, farbe );
+            }
         }
         }
     }
     }
     else
     else
     {
     {
-        for( int i = 0; i < br; ++i )
+        if( alpha )
+        {
+            for( int i = 0; i < br; ++i )
+            {
+                for( int x = pos.x; x < gr.x; x += 20 )
+                {
+                    Obj.drawLinieHAlpha( x + i + 1, y + i, min( 10, gr.x - i * 2 - 1 ), farbe );
+                    Obj.drawLinieHAlpha( x + i + 1, h - i, min( 10, gr.x - i * 2 - 1 ), farbe );
+                }
+                for( int y = pos.y; y < gr.y; y += 20 )
+                {
+                    Obj.drawLinieVAlpha( b - i, y + i + 1, min( 10, gr.y - i * 2 - 2 ), farbe );
+                    Obj.drawLinieVAlpha( x + i, y + i, min( 10, gr.y - i * 2 ), farbe );
+                }
+            }
+        }
+        else
         {
         {
-            Obj.drawLinieH( x + i + 1, y + i, gr.x - i * 2 - 1, farbe );
-            Obj.drawLinieV( b - i, y + i + 1, gr.y - i * 2 - 2, farbe );
-            Obj.drawLinieH( x + i + 1, h - i, gr.x - i * 2 - 1, farbe );
-            Obj.drawLinieV( x + i, y + i, gr.y - i * 2, farbe );
+            for( int i = 0; i < br; ++i )
+            {
+                for( int x = pos.x; x < gr.x; x += 20 )
+                {
+                    Obj.drawLinieH( x + i + 1, y + i, min( 10, gr.x - i * 2 - 1 ), farbe );
+                    Obj.drawLinieH( x + i + 1, h - i, min( 10, gr.x - i * 2 - 1 ), farbe );
+                }
+                for( int y = pos.y; y < gr.y; y += 20 )
+                {
+                    Obj.drawLinieV( b - i, y + i + 1, min( 10, gr.y - i * 2 - 2 ), farbe );
+                    Obj.drawLinieV( x + i, y + i, min( 10, gr.y - i * 2 ), farbe );
+                }
+            }
         }
         }
     }
     }
 }
 }
@@ -134,24 +186,62 @@ void Rahmen3D::render( Bild &Obj ) // Zeichnet den Rahmen in das RenderZeichnung
     int b = x + gr.x - 1;
     int b = x + gr.x - 1;
     int h = y + gr.y - 1;
     int h = y + gr.y - 1;
     int fcomp = ( farbe & 0xFF000000 ) | ( ~farbe & 0x00FFFFFF );
     int fcomp = ( farbe & 0xFF000000 ) | ( ~farbe & 0x00FFFFFF );
-    if( alpha )
+    if( !breaks )
     {
     {
-        for( int i = 0; i < br; ++i )
+        if( alpha )
         {
         {
-            Obj.drawLinieHAlpha( x + i + 1, y + i, gr.x - i * 2 - 1, farbe );
-            Obj.drawLinieVAlpha( b - i, y + i + 1, gr.y - i * 2 - 2, farbe );
-            Obj.drawLinieHAlpha( x + i + 1, h - i, gr.x - i * 2 - 1, fcomp );
-            Obj.drawLinieVAlpha( x + i, y + i, gr.y - i * 2, fcomp );
+            for( int i = 0; i < br; ++i )
+            {
+                Obj.drawLinieHAlpha( x + i + 1, y + i, gr.x - i * 2 - 1, farbe );
+                Obj.drawLinieVAlpha( b - i, y + i + 1, gr.y - i * 2 - 2, farbe );
+                Obj.drawLinieHAlpha( x + i + 1, h - i, gr.x - i * 2 - 1, fcomp );
+                Obj.drawLinieVAlpha( x + i, y + i, gr.y - i * 2, fcomp );
+            }
+        }
+        else
+        {
+            for( int i = 0; i < br; ++i )
+            {
+                Obj.drawLinieH( x + i + 1, y + i, gr.x - i * 2 - 1, farbe );
+                Obj.drawLinieV( b - i, y + i + 1, gr.y - i * 2 - 2, farbe );
+                Obj.drawLinieH( x + i + 1, h - i, gr.x - i * 2 - 1, fcomp );
+                Obj.drawLinieV( x + i, y + i, gr.y - i * 2, fcomp );
+            }
         }
         }
     }
     }
     else
     else
     {
     {
-        for( int i = 0; i < br; ++i )
+        if( alpha )
+        {
+            for( int i = 0; i < br; ++i )
+            {
+                for( int x = pos.x; x < gr.x; x += 20 )
+                {
+                    Obj.drawLinieHAlpha( x + i + 1, y + i, min( 10, gr.x - i * 2 - 1 ), farbe );
+                    Obj.drawLinieHAlpha( x + i + 1, h - i, min( 10, gr.x - i * 2 - 1 ), fcomp );
+                }
+                for( int y = pos.y; y < gr.y; y += 20 )
+                {
+                    Obj.drawLinieVAlpha( b - i, y + i + 1, min( 10, gr.y - i * 2 - 2 ), farbe );
+                    Obj.drawLinieVAlpha( x + i, y + i, min( 10, gr.y - i * 2 ), fcomp );
+                }
+            }
+        }
+        else
         {
         {
-            Obj.drawLinieH( x + i + 1, y + i, gr.x - i * 2 - 1, farbe );
-            Obj.drawLinieV( b - i, y + i + 1, gr.y - i * 2 - 2, farbe );
-            Obj.drawLinieH( x + i + 1, h - i, gr.x - i * 2 - 1, fcomp );
-            Obj.drawLinieV( x + i, y + i, gr.y - i * 2, fcomp );
+            for( int i = 0; i < br; ++i )
+            {
+                for( int x = pos.x; x < gr.x; x += 20 )
+                {
+                    Obj.drawLinieH( x + i + 1, y + i, min( 10, gr.x - i * 2 - 1 ), farbe );
+                    Obj.drawLinieH( x + i + 1, h - i, min( 10, gr.x - i * 2 - 1 ), fcomp );
+                }
+                for( int y = pos.y; y < gr.y; y += 20 )
+                {
+                    Obj.drawLinieV( b - i, y + i + 1, min( 10, gr.y - i * 2 - 2 ), farbe );
+                    Obj.drawLinieV( x + i, y + i, min( 10, gr.y - i * 2 ), fcomp );
+                }
+            }
         }
         }
     }
     }
 }
 }

+ 6 - 0
Rahmen.h

@@ -13,6 +13,7 @@ namespace Framework
         int br;
         int br;
         int farbe;
         int farbe;
         bool alpha;
         bool alpha;
+        bool breaks;
 
 
     public:
     public:
         // Konstruktor 
         // Konstruktor 
@@ -22,6 +23,9 @@ namespace Framework
         // Setzt die Breite des Rahmens
         // Setzt die Breite des Rahmens
         //  br: Die Breite in Pixeln
         //  br: Die Breite in Pixeln
         __declspec( dllexport ) void setRamenBreite( int br );
         __declspec( dllexport ) void setRamenBreite( int br );
+        // wenn dieser Flag gesetzt wird, wird der Rahmen gestrichelt gezeichnet
+        //  br: 1 -> gestrichelt, 0 -> durchgehend
+        __declspec( dllexport ) void setBreaks( bool br );
         // Gibt die Breite des Rahmens in Pixeln zurück
         // Gibt die Breite des Rahmens in Pixeln zurück
         __declspec( dllexport ) int getRBreite() const;
         __declspec( dllexport ) int getRBreite() const;
         // Legt fest, ob beim zeichnen alpha blending verwendet werden soll
         // Legt fest, ob beim zeichnen alpha blending verwendet werden soll
@@ -34,6 +38,8 @@ namespace Framework
         __declspec( dllexport ) int getFarbe() const;
         __declspec( dllexport ) int getFarbe() const;
         // Gibt zurück, ob der Rahmen mit Alpha Blending gezeichnet wird
         // Gibt zurück, ob der Rahmen mit Alpha Blending gezeichnet wird
         __declspec( dllexport ) bool hatAlpha() const;
         __declspec( dllexport ) bool hatAlpha() const;
+        // Gibt 1 zurück, falls der Rahmen gestrichelt gezeichnet wird
+        __declspec( dllexport ) bool hasBreaks() const;
     };
     };
 
 
     // Eine Zeichnung des 2D GUI Frameworks, die einen Linienrahmen um ein Rechteck zeichnet
     // Eine Zeichnung des 2D GUI Frameworks, die einen Linienrahmen um ein Rechteck zeichnet