PHPKonf ─░stanbul PHP Conference 2015

ImagickDraw::affine

(PECL imagick 2.0.0)

ImagickDraw::affineAdjusts the current affine transformation matrix

Description

bool ImagickDraw::affine ( array $affine )
Warning

This function is currently not documented; only its argument list is available.

Adjusts the current affine transformation matrix with the specified affine transformation matrix.

Parameters

affine

Affine matrix parameters

Return Values

No value is returned.

Examples

Example #1 ImagickDraw::affine()

<?php
function affine($strokeColor$fillColor$backgroundColor) {

    
$draw = new \ImagickDraw();

    
$draw->setStrokeWidth(1);
    
$draw->setStrokeOpacity(1);
    
$draw->setStrokeColor($strokeColor);
    
$draw->setFillColor($fillColor);

    
$draw->setStrokeWidth(2);

    
$PI 3.141592653589794;
    
$angle 60 $PI 360;

    
//Scale the drawing co-ordinates.
    
$affineScale = array("sx" => 1.75"sy" => 1.75"rx" => 0"ry" => 0"tx" => 0"ty" => 0);

    
//Shear the drawing co-ordinates.
    
$affineShear = array("sx" => 1"sy" => 1"rx" => sin($angle), "ry" => -sin($angle), "tx" => 0"ty" => 0);

    
//Rotate the drawing co-ordinates. The shear affine matrix
    //produces incorrectly scaled drawings.
    
$affineRotate = array("sx" => cos($angle), "sy" => cos($angle), "rx" => sin($angle), "ry" => -sin($angle), "tx" => 0"ty" => 0,);

    
//Translate (offset) the drawing
    
$affineTranslate = array("sx" => 1"sy" => 1"rx" => 0"ry" => 0"tx" => 30"ty" => 30);

    
//The identiy affine matrix
    
$affineIdentity = array("sx" => 1"sy" => 1"rx" => 0"ry" => 0"tx" => 0"ty" => 0);

    
$examples = [$affineScale$affineShear$affineRotate$affineTranslate$affineIdentity,];

    
$count 0;

    foreach (
$examples as $example) {
        
$draw->push();
        
$draw->translate(($count 2) * 250intval($count 2) * 250);
        
$draw->translate(100100);
        
$draw->affine($example);
        
$draw->rectangle(-50, -505050);
        
$draw->pop();
        
$count++;
    }

    
//Create an image object which the draw commands can be rendered into
    
$image = new \Imagick();
    
$image->newImage(500750$backgroundColor);
    
$image->setImageFormat("png");

    
//Render the draw commands in the ImagickDraw object 
    //into the image.
    
$image->drawImage($draw);

    
//Send the image to the browser
    
header("Content-Type: image/png");
    echo 
$image->getImageBlob();
}

?>

add a note add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top