TEXT mittels GD und transparentem Hintergrund erstellen

Collapse
X
 
  • Filter
  • Time
  • Show
Clear All
new posts

  • TEXT mittels GD und transparentem Hintergrund erstellen

    Hallo,

    hat jemand eine Ahnung wie die Jungs von Frisr, Friseurbesuch - Gutschein Idee
    das Erstellen der transparenten gifs mit Text so sauber hinbekommen haben?
    Bei mir ist die Qualität ganz schlecht wenn man dem Text eine andere Farbe als schwarz gibt.

  • #2
    Hier mein code:
    Code:
    $req = explode('|', $_REQUEST['r']);
        $text = $req[0];
        header ("Content-type: image/gif");
        $font = getFont($req[2]);
        $font_size = $req[1];
        $tmpcolor = getColor($req[3]);    
        $tmp_image=@imagecreatefromgif('gfx/transparent.gif');
        $width = imagesx($tmp_image);
        $height = imagesy($tmp_image);
    
        //calculate the new width / height
        $tmp = imagettfbbox($font_size,0,$font,$text);
        $new_width = $tmp[2]+10;
        $new_height = $font_size+5;
    
        $new_image = imagecreate($new_width,$new_height);
        ImageCopyResized($new_image, $tmp_image,0,0,0,0, $new_width, $new_height, $width, $height);
        $black = ImageColorAllocate($new_image,  0, 0,0);
        $trans = ImageColortransparent($new_image,$black);
        $color = ImageColorAllocate($new_image, trim($tmpcolor[0]), trim($tmpcolor[1]),
     trim($tmpcolor[2]));
        imagettftext($new_image, $font_size, 0, 0, $font_size, $color, $font, $text);
        //Grab new image
        imagegif($new_image);
        imagedestroy($new_image);
        imagedestroy($tmp_image);
    Last edited by dakingno1; 25-06-2010, 08:06.

    Comment


    • #3
      Hallo,

      das GIF das du am Anfang lädst hat vermutlich eine ungünstige Palette, die eher auf Graustufen optimiert ist. Du brauchst dann eine, die deine Textfarbe in verschiedenen Helligkeitsabstufungen enthält. D. h. im Endeffekt, dass du die Palette jeweils wirst generieren müssen.

      Gruß,

      Amica
      Last edited by AmicaNoctis; 24-06-2010, 17:29.
      [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
      Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
      Super, danke!
      [/COLOR]

      Comment


      • #4
        Originally posted by AmicaNoctis View Post
        Hallo,
        D. h. im Endeffekt, dass du die Palette jeweils wirst generieren müssen.

        Gruß,

        Amica
        Hallo,

        mit Grafiken kenne ich mich nicht ganz so gtu aus, kannst du mir bitte genauer erläutern was du mit Palette generieren meinst? Vielen Dank

        Comment


        • #5
          Originally posted by dakingno1 View Post
          mit Grafiken kenne ich mich nicht ganz so gtu aus
          Warum willst du dann unbedingt GIF haben? Nimm PNG und gut. Bessere Qualität, volle Alpha-Transparenz sprechen doch dafür.
          [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
          Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
          Super, danke!
          [/COLOR]

          Comment


          • #6
            Weil das Ergebnis genau so schlecht ist. Der Radn des textes wird nicht sauber übernommen. Das sieht man wenn das gif nicht auf weißem Hintergrund legt ganz gut: http://img534.imageshack.us/img534/3774/create.png

            Hier der Code:

            PHP Code:
            $req explode('|'$_REQUEST['r']);
                
            $text $req[0];
                
            header ("Content-type: image/png");
                
            $font getFont($req[2]);
                
            $font_size $req[1];
                
            $tmpcolor getColor($req[3]);    
                
            $tmp_image=@imagecreatefrompng('gfx/png_trans.png');
                
            $width imagesx($tmp_image);
                
            $height imagesy($tmp_image);

                
            //calculate the new width / height
                
            $tmp imagettfbbox($font_size,0,$font,$text);
                
            $new_width $tmp[2]+10;
                
            $new_height $font_size+5;

                
            $new_image imagecreate($new_width,$new_height);
                
            ImageCopyResized($new_image$tmp_image,0,0,0,0$new_width$new_height$width$height);
                
            $black ImageColorAllocate($new_image,  00,0);
                
            //$trans = ImageColortransparent($new_image,$black);
                
            $color ImageColorAllocate($new_imagetrim($tmpcolor[0]), trim($tmpcolor[1]),
             
            trim($tmpcolor[2]));
                
            imagettftext($new_image$font_size00$font_size$color$font$text);
                
            //Grab new image
                
            imagepng($new_image);
                
            imagedestroy($new_image);
                
            imagedestroy($tmp_image); 

            Comment


            • #7
              Du musst
              PHP Code:
              imagealphablending($imgfalse);
              imagesavealpha($imgtrue); 
              setzen, bevor du auf das Bild malst oder schreibst. Warum lädst du eigentlich immer erstmal ein Bild?

              Zum Thema Bounding Box habe ich hier noch etwas, das vielleicht interessant sein könnte: Warum imagettfbbox nichts taugt
              [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
              Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
              Super, danke!
              [/COLOR]

              Comment


              • #8
                Meinst du warum ich den Text als Bild ausgeben will oder warum ich als erstes ein transparentes.gif lade?

                Bei erstens liegt es daran weil ich bestimmte fonts ausgeben möchte und bei zweitens, weil die Funktion zum setzen von Farbe auf Transparenz ein noch schlechteres Ergebnis zurückliefert. Zumindest habe ich bisher keine bessere Methode gefunden um Text mit transparentem Hintergrund auszugeben.

                Die beiden Zeilen haben leider nichst bewirkt.

                Comment


                • #9
                  Hab mich vertan, der Wert bei imagealphablending muss true sein.
                  [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
                  Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
                  Super, danke!
                  [/COLOR]

                  Comment


                  • #10
                    Aus meiner Wühlkiste:

                    PHP Code:
                    <?php
                        
                    function getTypographicHeights ($pFont$pSize) {
                            
                    $bBox imagettfbbox($pSize0$pFont"x");
                            
                    $xLine $bBox[1] - $bBox[7];
                            
                    $bBox imagettfbbox($pSize0$pFont"p");
                            
                    $pLine $xLine $bBox[1] + $bBox[7];
                            
                    $bBox imagettfbbox($pSize0$pFont"k");
                            
                    $kLine $bBox[1] - $bBox[7];
                            
                    $bBox imagettfbbox($pSize0$pFont"H");
                            
                    $hLine $bBox[1] - $bBox[7];
                            
                    $bBox imagettfbbox($pSize0$pFont"ÁÂÃÄÅĂČ");
                            
                    $accLine $bBox[1] - $bBox[7];
                            return array(
                    $pLine0$xLine$hLine$kLine$accLine);
                        }
                        function 
                    getKerningOffset ($pFont$pSize$pText) {
                            
                    $bBox imagettfbbox($pSize0$pFont"  ");
                            
                    $sWidth $bBox[2] - $bBox[0];
                            
                    $bBox imagettfbbox($pSize0$pFont"  " $pText);
                            
                    $width $bBox[2] - $bBox[0] - $sWidth;
                            
                    $bBox imagettfbbox($pSize0$pFont$pText);
                            
                    $kerning $bBox[2] - $bBox[0] - $width;
                            return 
                    $kerning;
                        }

                        
                    $text "dein Text";
                        
                    $size 50;            // font size
                        
                    $offset 10;          // amount of internal padding between the text and the edges of the image
                        
                    $font "georgiaz.ttf";// path to your font file

                        
                    $bBox imagettfbbox($size0$font$text);
                        
                    $lines getTypographicHeights($font$size);
                        
                    $kerning getKerningOffset($font$size$text);
                        
                    $baseLine $lines[5];
                        
                    $left $bBox[0] + $offset;
                        
                    $img imagecreatetruecolor($bBox[2] - $bBox[0] + 2*$offset$lines[5] - $lines[0] + 2*$offset);
                        
                    imagealphablending($imgtrue);
                        
                    imagesavealpha($imgtrue);
                        
                    $cBackGround imagecolorallocatealpha($img000127); // transparent background
                        
                    $cText imagecolorallocatealpha($img2550064);      // semi-transparent text color

                        
                    imagefill($img00$cBackGround);
                        
                    imagettftext($img$size0$left $kerning$offset $baseLine$cText$font$text);

                        
                    header("Content-Type: image/png");
                        
                    imagepng($img)
                    ?>
                    [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
                    Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
                    Super, danke!
                    [/COLOR]

                    Comment


                    • #11
                      Super Klasse!!!!!

                      1000 Dank!!!!!



                      Das funzt perfekt nach einigen kleinen Anpassungen für die größe des Bildes.

                      Comment

                      Working...
                      X