Интегрирующий Фотолог - PullRequest
4 голосов
/ 12 октября 2009

Я хочу интегрировать фотолог с моим приложением 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

Ответы [ 2 ]

8 голосов
/ 13 октября 2009

Для ваших целей я бы порекомендовал вам проверить django-imagekit (я написал и imagekit, и фотолог). Он был разработан для интеграции в другие приложения, а не в отдельное приложение. После этого, как сказал Доминик, нам нужно больше узнать о ваших требованиях.

5 голосов
/ 16 октября 2009

Я использую 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

В представлении / шаблоне вы можете отфильтровать его

...