Django を使用して、標準の ImageField を使用してアップロードされた画像のサムネイルを作成し、通常の imagefile フィールドと一緒に別のフィールド 'thumbnail' にテーブルへのパスを追加しています。表示できるように、フォームセットを使用してカスタムテンプレートでイメージフィールドオブジェクトをレンダリングするサムネイルパスにアクセスする方法を考え出しています。
「form=CarImageForm」を inlineformset_factory に追加してから、forms.py を変更する必要があると思いますが、その方法や、このアプローチが正しいかどうかさえもわかりません。わかりやすくするために、以下のコード サンプルにはその試みを含めていません。
私の最終目標は、元の画像にリンクするサムネイル画像を返すことです-すでに Imagefile フィールドを介して表示されています。
前もって感謝します!
テンプレートは次のとおりです。
<form method="post" action="" enctype="multipart/form-data">
{% csrf_token %}
{{ formset.management_form }}
{% for form in formset.forms %}
{% for field in form %}
{{ field.label }}: {{ field }}<br>
{% endfor %}
{% endfor %}
<p><input type="submit" value="Enter"/></p>
フォーム.py:
class CarForm(ModelForm):
class Meta:
model = Car
exclude = ['owner', 'uploaded']
ビュー.py:
# Edit an existing record
@login_required
def edit_existing(request, object_id=False):
try:
car = Car.objects.get(pk=object_id)
except Car.DoesNotExist:
raise Http404
ImageFormSet = inlineformset_factory(Car, CarImage, extra=1, max_num=1)
if request.method == 'POST':
form = forms.CarForm(request.POST, instance=car)
formset = ImageFormSet(request.POST, request.FILES, instance=car)
if formset.is_valid() and form.is_valid():
# Handle form.save() to include user id
new_car = form.save(commit=False)
new_car.owner = request.user
new_car.save()
# Formset - contains the attached images
formset.save()
return HttpResponseRedirect(new_car.get_absolute_url())
else:
form = forms.CarForm(instance=car)
formset = ImageFormSet(instance=car)
return render_to_response('edit_existing.html',
{'form': form, 'formset': formset},
context_instance=RequestContext(request))
models.py:
class Car(models.Model):
make = models.CharField(max_length=64)
model = models.CharField(max_length=64)
owner = models.ForeignKey(User,editable=False)
uploaded = models.DateField(default=datetime.date.today,editable=False)
def get_absolute_url(self):
return reverse('vehicle_admin.views.car_detail', args=[str(self.id)])
def orig_car_id_folder(instance, filename):
return 'uploads/images/orig/{0}/{1}'.format(instance.car_id, filename)
def thumb_car_id_folder(instance, filename):
return 'uploads/images/thumb/{0}/{1}'.format(instance.car_id, filename)
class CarImage(models.Model):
car = models.ForeignKey(Car)
imagefile = models.ImageField(upload_to=orig_car_id_folder)
thumbnail = models.ImageField(upload_to=thumb_car_id_folder, editable=False)
# PIL tips from
# https://snipt.net/danfreak/generate-thumbnails-in-django-with-pil/
# http://www.mechanicalgirl.com/post/image-resizing-file-uploads-doing-it-easy-way/
def save(self):
import os
from PIL import Image
from cStringIO import StringIO
from django.core.files.uploadedfile import SimpleUploadedFile
THUMBNAIL_SIZE = (75, 75)
super(CarImage, self).save() # Use the commit=False param here?
image = Image.open(self.imagefile.path)
if image.mode not in ('L', 'RGB'):
image = image.convert('RGB')
image.thumbnail(THUMBNAIL_SIZE, Image.ANTIALIAS)
temp_handle = StringIO()
image.save(temp_handle, 'png')
temp_handle.seek(0)
name_ext = os.path.splitext(os.path.split(self.imagefile.name)[-1])
suf = SimpleUploadedFile(name_ext[0],
temp_handle.read(), content_type='image/png')
self.thumbnail.save(suf.name+'.png', suf, save=False)
super(CarImage, self).save()