Download the PHP package crisu83/yii-imagemanager without Composer
On this page you can find all versions of the php package crisu83/yii-imagemanager. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download crisu83/yii-imagemanager
More information about crisu83/yii-imagemanager
Files in crisu83/yii-imagemanager
Package yii-imagemanager
Short Description Image manager for the Yii PHP framework.
License BSD-3-Clause
Informations about the package yii-imagemanager
yii-imagemanager
Image manager extension for the Yii PHP framework.
Introduction
I started this project to reduce the need for boilerplate code when working with images in my Yii applications. The goal was not to provide an user interface for image management but to wrap the powerful Imagine library using Yii's conventions. Imagine is one of the best image manipulation libraries for PHP and comes with a wide range of different image filters and supports all the major graphics libraries.
This extension is an extension to my yii-filemanager extension.
Features
- A wide range of image filters such as crop, resize and thumbnail
- Image presets with support for caching of generated images
- Support for both server and client -side (through holder.js) placeholders
- Storing of uploaded images in the database
- Supports multiple graphics libraries including GD, Imagick and Gmagick
- Application component that provides centralized access
- Active record behavior to ease working with the API
Setup
The easiest way to get started with the yii-imagemanager is to install it using Composer. That way Composer will take care of installing its dependancies, the yii-filemanager and Imagine. Alternatively you can download the extension and it's dependencies manually. Just make sure that all the libraries are registered with the autoloader.
Add the following rows your composer.json file:
Run the following command in the root directory of your project:
Add the image manager application component to your application configuration:
The following configuration parameters are available for the image manager:
- driver the image driver to use, valid drivers are , and
- presets the preset filter configurations (name => config)
- holders the placeholder image configurations (name => filename)
- imageDir the name of the images directory
- rawDir the name of the directory with the unmodified images
- cacheDir the name of the direcotry with the cached images
- holderDir the name of the directory with placeholder images
- clientHolderText the text used with client-side placeholders
- modelClass the name of the image model class
- dependencies the map over dependency paths (name => path)
- filterManagerID the component ID for the file manager component
Add the image command to your console application configuration:
Run the following command through yiic:
The following arguments are available for the createAccessFile action:
- baseUrl the rewrite base url to use
- path the full path to the access file to create
What's included?
- ImageBehavior behavior that ease saving, rendering and deleting of images associated with active records
- ImageCommand console command for running shell tasks
- ImageManager application component that provides centralized access
- ImagePreset component that defines a single image preset
- ImageController controller for running actions via an URL
- ImagineFilter the base class for all the image filters
- Image model class for the image table
Getting started
Once your have configured everything you are ready to start using the image manager. Below I will try to explain the most basic features and how to use them.
Configure presets and placeholders
We need to add a few more things to your application configuration before we can begin. In this example we will add a preset and a placeholder image to the image manager. Add the following lines to your application configuration:
Attach the image behavior to your model
Let us assume that you have a model called Product for which you want to upload images. In order to do so we need to add an imageId column to your user table where we can store the id for the associated image model. To attach the behavior we add the following code to the Product class:
Uploading and saving the image
Alright, now we can save images through the Product model. Next we will add an action that renders a view that contains a form with a file input. When the form is submitted the uploaded image should be saved in the database. Here is the code for both the action and the view:
There's more
This is just scratching the surface of what you can do with this extension, there are a lot of filters to explore and you can also work with the image manager API directly without the image behavior if you desire. The best way to learn to use this extension is to read through its code, especially the ImageManager application component. Good luck!
All versions of yii-imagemanager with dependencies
crisu83/yii-extension Version >=1.2.0
crisu83/yii-filemanager Version >=1.9.1
imagine/imagine Version 0.6.*@dev