Mit PHP zeichnen - Eine Grafik mit PHP erstellen (Tutorial)

[Bildschirmfoto] Mit PHP zeichnen - Eine Grafik mit PHP erstellen (Tutorial)

Mit den Grafikfunktionen können Sie zur Laufzeit des PHP-Scripts auch Grafiken erzeugen.
➤ Voraussetzung ist eine installierte GD-Grafikbibliothek auf dem Webserver.
Siehe auch: GD-Bibliothek unter XAMPP aktivieren

Die aktuelle Version dieser Bibliothek liegt normalerweise der PHP-Distribution bei.
Ob die GD-Bibliothek in Ihrer PHP-Version verfügbar ist, können Sie mit der Anweisung:
<?=phpinfo();?> herausfinden. In der Ausgabe müsste dann, unter anderem sowas stehen:

[Bildschirmfoto] In der PHP-Info kann man auch sehen, welche Bildformate unterstützt werden.
In der PHP-Info kann man auch sehen, welche Bildformate unterstützt werden.

Grafik erstellen

Grafik-Header (image/png) an den Browser senden:


<?php

header
("Content-type: image/png");

➤ Wichtig ist, das vor dem HTML-Tag (<php) keine Zeichen (auch keine Leerzeichen)
stehen, sonst wird die Grafik nicht angezeigt.

Den schließenden HTML-Tag (?>) lassen wir weg, dieser wird nicht benötigt und beugt Fehlern vor!

Breite und Höhe der Grafik angeben:


<?php

$breite 
250;
$hoehe 150;
$marsbild imageCreateTruecolor($breite$hoehe);

Farbe für den Hintergrund erstellen:


<?php

$wasserfarbe 
imageColorAllocate($marsbild109191210);

Die Farbangaben erfolgen mit RGB (Rot, Grün, Blau) Zahlenwerte von 0 bis 255.
Siehe: Farbnamen, Hexadezimal, Dezimal, Prozent und Negativ

Grafik mit der Hintergrundfarbe füllen:


<?php

imageFill
($marsbild00$wasserfarbe);

0 = Position vom linken und oberen Grafikrand.

Ausgabe der Grafik an den Browser senden:


<?php

imagePng
($marsbild);

Grafik aus dem Speicher entfernen:
Zuletzt sollte man die Grafik wieder aus dem Speicher entfernen, um den Speicher des Webservers nicht unnötig zu belasten.


<?php

imageDestroy
($marsbild);

Die erstellte Grafik:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<?php
// Marsbewohner 1

$breite 250// Breite der Grafik
$hoehe 150// Höhe der Grafik
$marsbild imageCreateTruecolor($breite$hoehe); // Grafik erstellen

$wasserfarbe imageColorAllocate($marsbild109191210); // Farbe für den Hintergrund erstellen
imageFill($marsbild00$wasserfarbe); // Grafik mit der Hintergrundfarbe füllen

header("Content-type: image/png"); // Grafik-Header (image/png) an den Browser senden

imagePng($marsbild); // Ausgabe der Grafik an den Browser senden
imageDestroy($marsbild); // Grafik aus dem Speicher entfernen

Die Grafik-Header-Anweisung: header("Content-type: image/png"); wurde im Skript in eine Zeile kurz vor der Ausgabe an den Browser verschoben. Dadurch werden etwaige PHP-Fehlermeldungen im Skript auch angezeigt.

 

Einen Kreis (Insel) in die Grafik zeichnen

Farbe für den Kreis erstellen:


<?php

$inselfarbe 
imageColorAllocate($marsbild1546948);

Die Farbangaben erfolgen auch hier mit RGB.

Einen gefüllten Kreis (Ellipse) zeichnen:


<?php

imageFilledEllipse
($marsbild12290220100$inselfarbe);

122 = Position vom linken Grafikrand.
90 = Position vom oberen Grafikrand.
220 = Breite der Grafik.
100 = Höhe der Grafik.

Die erstellte Grafik:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<?php
// Marsbewohner 2

$breite 250// Breite der Grafik
$hoehe 150// Höhe der Grafik
$marsbild imageCreateTruecolor($breite$hoehe); // Grafik erstellen

$wasserfarbe imageColorAllocate($marsbild109191210); // Farbe für den Hintergrund erstellen
imageFill($marsbild00$wasserfarbe); // Grafik mit der Hintergrundfarbe füllen

$inselfarbe imageColorAllocate($marsbild1546948); // Farbe für den Kreis (Insel) erstellen
imageFilledEllipse($marsbild12290220100$inselfarbe); // Einen gefüllten Kreis (Elipse) zeichnen

header("Content-type: image/png"); // Grafik-Header (image/png) an den Browser senden

imagePng($marsbild); // Ausgabe der Grafik an den Browser senden
imageDestroy($marsbild); // Grafik aus dem Speicher entfernen

 

Ein Quadrat (Haus) in die Grafik zeichnen

Quadrat zeichnen:


<?php

$hausrahmenfarbe 
imageColorAllocate($marsbild000);
imageRectangle($marsbild5555120120$hausrahmenfarbe);

55 = Position der linken oberen Ecke.
120 = Position der rechten unteren Ecke.

Quadrat mit Farbe füllen:


<?php

$hausfarbe 
imageColorAllocate($marsbild128128128);
imageFill($marsbild5656$hausfarbe);

56 = Position der linken oberen Ecke + 1.

Die erstellte Grafik:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<?php
// Marsbewohner 3

$breite 250// Breite der Grafik
$hoehe 150// Höhe der Grafik
$marsbild imageCreateTruecolor($breite$hoehe); // Grafik erstellen

$wasserfarbe imageColorAllocate($marsbild109191210); // Farbe für den Hintergrund erstellen
imageFill($marsbild00$wasserfarbe); // Grafik mit der Hintergrundfarbe füllen

$inselfarbe imageColorAllocate($marsbild1546948); // Farbe für den Kreis (Insel) erstellen
imageFilledEllipse($marsbild12290220100$inselfarbe); // Einen gefüllten Kreis (Elipse) zeichnen

$hausrahmenfarbe imageColorAllocate($marsbild000); // Farbe für das Quatrat (Haus) erstellen
imageRectangle($marsbild5555120120$hausrahmenfarbe); // Quatrat zeichnen

$hausfarbe imageColorAllocate($marsbild128128128); // Farbe für das Quatrat (Haus) erstellen
imageFill($marsbild5656$hausfarbe); // Grafik mit der Hintergrundfarbe füllen

header("Content-type: image/png"); // Grafik-Header (image/png) an den Browser senden

imagePng($marsbild); // Ausgabe der Grafik an den Browser senden
imageDestroy($marsbild); // Grafik aus dem Speicher entfernen

 

2 Dreiecke („Marsianer”) in die Grafik zeichnen


<?php

$marsianerfarbe 
imageColorAllocate($marsbild1272550);
$marsianer1 = array(70,95,   80,75,   90,95);
$marsianer2 = array(150,95,   160,115,   170,95);

Farbe und die Koordinaten der Dreiecke auf der Grafik.

Dreiecke zeichnen:


<?php

imageFilledPolygon
($marsbild$marsianer13$marsianerfarbe);
imageFilledPolygon($marsbild$marsianer23$marsianerfarbe);

Die erstellte Grafik:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<?php
// Marsbewohner 4

$breite 250// Breite der Grafik
$hoehe 150// Höhe der Grafik
$marsbild imageCreateTruecolor($breite$hoehe); // Grafik erstellen

$wasserfarbe imageColorAllocate($marsbild109191210); // Farbe für den Hintergrund erstellen
imageFill($marsbild00$wasserfarbe); // Grafik mit der Hintergrundfarbe füllen

$inselfarbe imageColorAllocate($marsbild1546948); // Farbe für den Kreis (Insel) erstellen
imageFilledEllipse($marsbild12290220100$inselfarbe); // Einen gefüllten Kreis (Elipse) zeichnen

$hausrahmenfarbe imageColorAllocate($marsbild000); // Farbe für das Quatrat (Haus) erstellen
imageRectangle($marsbild5555120120$hausrahmenfarbe); // Quatrat zeichnen

$hausfarbe imageColorAllocate($marsbild128128128); // Farbe für das Quatrat (Haus) erstellen
imageFill($marsbild5656$hausfarbe); // Grafik mit der Hintergrundfarbe füllen

$marsianerfarbe imageColorAllocate($marsbild1272550); // Farbe für das Dreieck erstellen
$marsianer1 = array(70,95,   80,75,   90,95); // Koordinaten des 1 Dreiecks auf der Grafik
$marsianer2 = array(150,95,   160,115,   170,95); // Koordinaten des 2 Dreiecks auf der Grafik

imageFilledPolygon($marsbild$marsianer13$marsianerfarbe); // Dreieck zeichnen
imageFilledPolygon($marsbild$marsianer23$marsianerfarbe); // Dreieck zeichnen

header("Content-type: image/png"); // Grafik-Header (image/png) an den Browser senden

imagePng($marsbild); // Ausgabe der Grafik an den Browser senden
imageDestroy($marsbild); // Grafik aus dem Speicher entfernen

 

Text in die Grafik einfügen


<?php

$schriftfarbe 
imageColorAllocate($marsbild25500);
ImageString($marsbild61510"Live from Mars"$schriftfarbe);

6 = Schriftgröße (0 - 6)
15 = Position von links
10 = Position von oben

Die erstellte Grafik:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<?php
// Marsbewohner 5

$breite 250// Breite der Grafik
$hoehe 150// Höhe der Grafik
$marsbild imageCreateTruecolor($breite$hoehe); // Grafik erstellen

$wasserfarbe imageColorAllocate($marsbild109191210); // Farbe für den Hintergrund erstellen
imageFill($marsbild00$wasserfarbe); // Grafik mit der Hintergrundfarbe füllen

$inselfarbe imageColorAllocate($marsbild1546948); // Farbe für den Kreis (Insel) erstellen
imageFilledEllipse($marsbild12290220100$inselfarbe); // Einen gefüllten Kreis (Elipse) zeichnen

$hausrahmenfarbe imageColorAllocate($marsbild000); // Farbe für das Quatrat (Haus) erstellen
imageRectangle($marsbild5555120120$hausrahmenfarbe); // Quatrat zeichnen

$hausfarbe imageColorAllocate($marsbild128128128); // Farbe für das Quatrat (Haus) erstellen
imageFill($marsbild5656$hausfarbe); // Grafik mit der Hintergrundfarbe füllen

$marsianerfarbe imageColorAllocate($marsbild1272550); // Farbe für das Dreieck erstellen
$marsianer1 = array(70,95,   80,75,   90,95); // Koordinaten des 1 Dreiecks auf der Grafik
$marsianer2 = array(150,95,   160,115,   170,95); // Koordinaten des 2 Dreiecks auf der Grafik

imageFilledPolygon($marsbild$marsianer13$marsianerfarbe); // Dreieck zeichnen
imageFilledPolygon($marsbild$marsianer23$marsianerfarbe); // Dreieck zeichnen

$schriftfarbe imageColorAllocate($marsbild25500); // Farbe der Schrift
ImageString($marsbild61515"Live from Mars"$schriftfarbe); // Text in die Grafik zeichnen

header("Content-type: image/png"); // Grafik-Header (image/png) an den Browser senden

imagePng($marsbild); // Ausgabe der Grafik an den Browser senden
imageDestroy($marsbild); // Grafik aus dem Speicher entfernen

Es gibt vielfältige Möglichkeiten wie Sie die Grafik weiter gestalten können. Mit ein wenig JavaScript werden die Grafiken immer wieder neu geladen. Wer wissen will wie das funktioniert, der sollte in den Quelltext dieser Seite schauen.

Sie sehen also, der künstlerischen Freiheit sind mit Grafiken keine Grenzen gesetzt

Quelltext:  marsbewohner_10.php EinblendenKopierenLinkZeilen

Einbinden der Grafik in eine HTML-Seite

Einfach den Dateinamen der PHP-Datei (marsbewohner.php) im SRC-Attribut des <img>-Tags einfügen.

<img src="marsbewohner.php">

Beispiele herunterladen

marsbewohner.zip

Viel Spaß damit!