Django Field that implement those features:
- Rename files to a standardized name (using object id)
- Resize images for that field
- Automatically creates a thumbnail (resizing it)
- Allow image deletion
Install latest PIL - there is really no reason to use this package without it
easy_install django-stdimage
Put 'stdimage' in the INSTALLED_APPS
Import it in your project, and use in your models.
Example:
[...] from stdimage import StdImageField class MyClass(models.Model): image1 = StdImageField(upload_to='path/to/img') # works as ImageField image2 = StdImageField(upload_to='path/to/img', blank=True) # can be deleted throwgh admin image3 = StdImageField(upload_to='path/to/img', variations={'thumbnail': (100, 75)}) # creates a thumbnail resized to maximum size to fit a 100x75 area image4 = StdImageField(upload_to='path/to/img', variations={'thumbnail': (100, 100, True}) # creates a thumbnail resized to 100x100 croping if necessary image_all = StdImageField(upload_to='path/to/img', blank=True, variations={'large': (640, 480), 'thumbnail': (100, 100, True)}) # all previous features in one declaration
For using generated thumbnail in templates use "myimagefield.thumbnail". Example:
[...] <a href="{{ object.myimage.url }}"><img alt="" src="{{ object.myimage.thumbnail.url }}"/></a> [...]
StdImageField stores images in filesystem modifying its name. Renamed name is set using field name, and object primary key. Also it changes old windows "jpg" extesions to standard "jpeg".
Using image_all field previously defined (that creates a thumbnail), if an image called myimage.jpg is uploaded, then resulting images on filesystem would be (supose that this image belongs to a model with pk 14):
image_all_14.jpeg image_all_14.large.jpeg image_all_14.thumbnail.jpeg