The ImagickPixelIterator::newPixelIterator() function is an inbuilt function in PHP which is used to get a new pixel iterator to iterate pixels of a imagick image.
Syntax:
bool ImagickPixelIterator::newPixelIterator( Imagick $wand )
Parameters: This function accepts a single parameter $wand which holds the image to iterate the pixels.
Return Value: This function returns TRUE on success.
Below programs illustrate the ImagickPixelIterator::newPixelIterator() function in PHP:
Program 1:
<?php   // Create a new imagick object $imagick = new Imagick();   // Create a image on imagick object $imagick ->newImage(800, 250, 'black' );   // Create a new ImagickPixelIterator instance $imageIterator = new ImagickPixelIterator();   // Get the pixels from the image $imageIterator ->newPixelIterator( $imagick );   $i = 0;   // Loop through pixel rows foreach ( $imageIterator as $row => $pixels ) {     $i ++; }    echo 'Total rows are ' . $i ; ?> |
Output:
Total rows are 250
Program 2:
<?php   // Create a new imagick object $imagick = new Imagick();   // Create a image on imagick object $imagick ->newImage(800, 250, 'black' );   // Create a new ImagickPixelIterator instance $imageIterator = new ImagickPixelIterator();   // Get the pixels from the image $imageIterator ->newPixelIterator( $imagick );   $colors = [ 'red' , 'green' , 'blue' , 'yellow' ]; $i = 0;   // Loop through pixel rows foreach ( $imageIterator as $row => $pixels ) {         foreach ( $pixels as $column => $pixel ) {           // Set the color of each pixel lines to colors         $pixel ->setColor( $colors [ $i % 4]);     }     $i ++;       // Sync the iterator after each iteration     $imageIterator ->syncIterator(); }    // Show the output $imagick ->setImageFormat( 'png' ); header( "Content-Type: image/png" ); echo $imagick ->getImageBlob(); ?> |
Output:
Reference: https://www.php.net/manual/en/imagickpixeliterator.newpixeliterator.php