1. Go to this page and download the library: Download jumper423/yii2-images library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
jumper423 / yii2-images example snippets
$model = Model::findOne(12); //Model must have id
//If an image is first it will be main image for this model
$model->attachImage('../../image.png');
//But if you need set another image as main, use second arg
$model->attachImage('../../image2.png', true);
//get all images
$images = $model->getImages();
foreach($images as $img){
//retun url to full image
echo $img->getUrl();
//return url to proportionally resized image by width
echo $img->getUrl('300x');
//return url to proportionally resized image by height
echo $img->getUrl('x300');
//return url to resized and cropped (center) image by width and height
echo $img->getUrl('200x300');
}
//Returns main model image
$image = $model->getImage();
if($image){
//get path to resized image
echo $image->getPath('400x300');
//path to original image
$image->getPathToOrigin();
//will remove this image and all cache files
$model->removeImage($image);
}
$model->getImage(); //returns main image for model (first added image or setted as main)
$model->removeImages(); //returns array with images
//If there is no images for model, above methods will return PlaceHolder images or null
//If you want placeholder set up it in module configuration (see documentation)
$model->removeImage($image); //you must to pass image (object)
$model->removeImages(); //will remove all images of this model
$model->attachImage($absolutePathToImage, true); //will attach image and make it main
foreach($model->getImages() as $img){
if($img->id == $ourId){
$model->setMainImage($img);//will set current image main
}
}
'modules' => [
'yii2images' => [
'class' => 'jumper423\yii2images\Module',
//be sure, that permissions ok
//if you cant avoid permission errors you have to create "images" folder in web root manually and set 777 permissions
'imagesStorePath' => 'images/store', //path to origin images
'imagesCachePath' => 'images/cache', //path to resized copies
'graphicsLibrary' => 'GD', //but really its better to use 'Imagick'
'placeHolderPath' => '@webroot/images/placeHolder.png', // if you want to get placeholder when image not exists, string will be processed by Yii::getAlias
],
],
public function behaviors()
{
return [
'image' => [
'class' => 'jumper423\yii2images\behaviors\ImageBehave',
]
];
}
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.