Image Preview on ImageField in admin

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
from django.contrib.admin.widgets import AdminFileWidget
from django.utils.translation import ugettext as _
from django.utils.safestring import mark_safe
import os
import Image

class AdminImageWidget(AdminFileWidget):
	def render(self, name, value, attrs=None):
		output = []
		if value and getattr(value, "url", None):
			
			image_url = value.url
			file_name=str(value)
			
			# defining the size
			size='100x100'
			x, y = [int(x) for x in size.split('x')]
			
			# defining the filename and the miniature filename
			filehead, filetail 	= os.path.split(value.path)
			basename, format 	= os.path.splitext(filetail)
			miniature 		= basename + '_' + size + format
			filename 		= value.path
			miniature_filename 	= os.path.join(filehead, miniature)
			filehead, filetail 	= os.path.split(value.url)
			miniature_url 		= filehead + '/' + miniature
			
			# make sure that the thumbnail is a version of the current original sized image
			if os.path.exists(miniature_filename) and os.path.getmtime(filename) > os.path.getmtime(miniature_filename):
				os.unlink(miniature_filename)
				
			# if the image wasn't already resized, resize it
			if not os.path.exists(miniature_filename):
				image = Image.open(filename)
				image.thumbnail([x, y], Image.ANTIALIAS)
				try:
					image.save(miniature_filename, image.format, quality=100, optimize=1)
				except:
					image.save(miniature_filename, image.format, quality=100)
			
			output.append(u' <div><a href="%s" target="_blank"><img src="%s" alt="%s" /></a></div> %s ' % \
			(miniature_url, miniature_url, miniature_filename, _('Change:')))
			
		output.append(super(AdminFileWidget, self).render(name, value, attrs))
		return mark_safe(u''.join(output))

More like this

  1. ImageField for admin with thumbnail by semente 4 years, 10 months ago
  2. ClearableFileInput with image preview by pafa 2 years, 5 months ago
  3. django easy_thumbnails AdminImageWidget by livskiy 1 year, 6 months ago
  4. Admin Image Widget + easy-thumbnails by babu 2 years, 10 months ago
  5. [UPDATE]Filter to resize a ImageField on demand by rafacdb 5 years, 8 months ago

Comments

kernel32ddl (on April 21, 2011):

Hi, what is the module "Image"?

#

TheEditor (on March 25, 2012):

How about a short example to show us how this is used? Hardly anybody ever does that around here.

#

(Forgotten your password?)