4

Photologue を Django アプリと統合し、それを使用して車両の在庫に写真を表示したいと考えています... Boost Motor Group Inc. が提供するものと似ています。私はすでにアプリを統合しているので、次のステップを試みています。それを私の車両モデルに接続する方法と、写真を表示する方法を理解する. 私の車両モデルはこのように見えます BTW

class Vehicle(models.Model):
    stock_number = models.CharField(max_length=6, blank=False)
    vin = models.CharField(max_length=17, blank=False)
    common_vehicle = models.ForeignKey(CommonVehicle)
    exterior_colour = models.ForeignKey(ExteriorColour)
    interior_colour = models.ForeignKey(InteriorColour)
    interior_type = models.ForeignKey(InteriorType)
    odometer_unit = models.ForeignKey(OdometerUnit)
    status = models.ForeignKey(Status)
    odometer_reading = models.PositiveIntegerField()
    selling_price = models.PositiveIntegerField()
    purchase_date = models.DateField()
    sales_description = models.CharField(max_length=60, blank=False)
    feature_sets = models.ManyToManyField(FeatureSet, blank=True)
    features = models.ManyToManyField(Feature, blank=True)

    def __unicode__(self):
        return self.stock_number
4

2 に答える 2

9

あなたの目的のために、django-imagekitをチェックすることをお勧めします(imagekit と photologue の両方を書きました)。スタンドアロン アプリケーション自体ではなく、他のアプリケーションに統合できるように設計されています。その後、ドミニクが言ったように、私たちはあなたの要件についてもっと知る必要があります.

于 2009-10-12T20:05:55.287 に答える
5

私はImageKitを使用しています(素晴らしい!)

model.py

from imagekit.models import ImageModel
class Photo(ImageModel):
    name = models.CharField(max_length=100)
    original_image = models.ImageField(upload_to='photos')
    num_views = models.PositiveIntegerField(editable=False, default=0)
    content_type = models.ForeignKey(ContentType)
    object_id = models.PositiveIntegerField()
    content_object = generic.GenericForeignKey('content_type', 'object_id')

    class IKOptions:
        # This inner class is where we define the ImageKit options for the model
        spec_module = 'cms.specs'
        cache_dir = 'photos'
        image_field = 'original_image'
        save_count_as = 'num_views'

class Vehicle(models.Model):
    images = generic.GenericRelation('Photo', blank = True, null = True)  

specs.py

from imagekit.specs import ImageSpec 
from imagekit import processors 
from imagekit.lib import *

# first we define our thumbnail resize processor 
class ResizeThumb(processors.Resize): 
    width = 100 
    height = 75 
    crop = True

# now lets create an adjustment processor to enhance the image at small sizes 
class EnchanceThumb(processors.Adjustment): 
    contrast = 1.2 
    sharpness = 1.1 

# now we can define our thumbnail spec 
class Thumbnail(ImageSpec): 
    processors = [ResizeThumb, EnchanceThumb] 

テンプレートでは、このサムネイルに次のようにアクセスします。

{% for p in vehicle.images.all %}
   {{ p.get_thumbnail.url }}
{% endfor %}

admin.py は次のようになります。

class ImagesInline(generic.GenericTabularInline):
    model = Photo
    max_num =4

class VehicleAdmin(admin.ModelAdmin):
    inlines = [ImagesInline]

ImageKitのすべて

ファイル specs.py をアプリに追加し、ImageKit に次のように伝えます。

  class IKOptions:
        # This inner class is where we define the ImageKit options for the model
        spec_module = 'cms.specs # ur_app.specs

フォトモデルにフィールドを追加して、表示するビュー/コンテンツの種類を保存します。つまり、ChoiceField

ビュー/テンプレートでは、それをフィルタリングできます

于 2009-10-16T16:11:48.247 に答える