Welcome, guest | Sign In | My Account | Store | Cart

Notice! PyPM is being replaced with the ActiveState Platform, which enhances PyPM’s build and deploy capabilities. Create your free Platform account to download ActivePython or customize Python with the packages you require and get automatic updates.

Download
ActivePython
INSTALL>
pypm install plone.scale

How to install plone.scale

  1. Download and install ActivePython
  2. Open Command Prompt
  3. Type pypm install plone.scale
 Python 2.7Python 3.2Python 3.3
Windows (32-bit)
1.3.2 Available View build log
1.2.2 Available View build log
1.2.1 Failed View build log
1.2 Available View build log
Windows (64-bit)
1.3.2 Available View build log
1.2.2 Available View build log
1.2.1 Failed View build log
1.2 Available View build log
Mac OS X (10.5+)
1.3.2 Available View build log
1.2.2 Available View build log
1.2.1 Failed View build log
1.2 Available View build log
Linux (32-bit)
1.3.2 Available View build log
1.2.2 Available View build log
1.2.1 Failed View build log
1.2 Available View build log
Linux (64-bit)
1.3.2 Available View build log
1.2.2 Available View build log
1.2.1 Failed View build log
1.2 Available View build log
 
License
BSD
Dependencies
Lastest release
version 1.3.2 on May 25th, 2013

Introduction

This package contains image scaling logic for use in Zope environments. It supports Zope 2, grok and other systems build on using the Zope ToolKit (ZTK).

Several design goals were used when writing this package:

  • image scaling to any width, height, width&height should be supported using both up-scaling and down-scaling. Scaling parameters should never be fixed in code. This allows designers to use any image scale they want without having to modify python code.
  • the result of scaling will be an image along with its new size, not a HTML or XHTML tag. We already have excellent tools to generate tags in the form of Zope Pagetemplates, Genshi and other template languages that are much better suited for this purpose.

In addition several implementation goals were defined:

  • image scaling must happen on demand instead of up-front. This reduces initial save time and prevents unnecessary scalings from being generated.
  • image scaling parameters should not be part of the generated URL. Since the number of parameters can change and new parameters may be added in the future this would create overly complex URLs and URL parsing.
  • no HTML rewriting (such as done by repoze.bitblt) should be required.
  • it should be possibly to develop an external storage system which stores scaled images externally and returns a URL which bypasses the application server. This should be configurable via just a filesystem path & base URL.
  • minimum number of external dependencies, allowing this package to be used in many environments.
  • testable without requiring zope.testing. Running setup.py test should be sufficient.
  • URLs for scaled images should have an extension which reflects their MIME type. This is facilitates cache (and other front-end services) configuration.

Usage

The most common way to use plone.scale is from a HTML template. In TAL syntax a typical usage looks like this:

<img tal:define="scales context/@@image-scaling;
                 thumbnail python:scales.scale('logo', width=64, height=64)"
     tal:attributes="src thumbnail/url;
                     width thumbnail/width;
                     height thumbnail/height" />

This generates a thumbnail of an image field called logo with a maximum size of 64x64 pixels. The dimensions of the resulting image (which might not be exactly 64x64) are set as attributes on the img tag to speed up browser rendering.

If you prefer Genshi syntax and have the IImageScaleStorage interface in scope the syntax looks like this:

<img py:with="thumbnail=IImageScaleStorage(context).scale('logo', width=64, heigh=64)"
     py:attributes="dict(src=thumbnail.url, width=thumbnail.width, height=thumbnail.height" />

Changelog

1.3.2 (2013-05-23)
1.3.1 (2013-04-06)
  • Cropped images are now centralised vertically as well as horizontally [mattss]
1.3 (2013-01-17)
  • Add MANIFEST.in. [WouterVH]
  • Break up scaleImage, so that its scaling-related parts can be applied to instances of PIL.Image for further processing. [witsch]
1.2.2 - 2010-09-28
1.2.1 - 2010-08-18
  • Convert CMYK to RGB, allowing for web previews of print images. [tomster]
1.2 - 2010-07-18
  • Update package metadata. [hannosch]
1.1 - 2010-04-20
  • Abort if thumbnail behaviour is requested but either width or height is missing. This is nicer than confronting the caller with a PIL exception. [wichert]
  • Rename the keep direction to thumbnail to make its behaviour more intuitive, but accept keep for now. [wichert]
1.0 - 2010-04-12
  • Only pull in the uuid distribution in Python versions before 2.5. [hannosch]
  • Don't declare dependency on PIL. [davisagli]
1.0a2 - 2010-04-10
  • Add BSD license text following board decision: http://lists.plone.org/pipermail/membership/2009-August/001038.html [elro]
  • Allow to use PIL's thumbnail algorithm to keep the present aspect ratio. [spamsch, witsch]
  • Allow to set the quality of the resulting image scales. [witsch]
  • Refactor storage adapter for image scales to be less dependent on the underlying content type. [witsch]
1.0a1 - 2009-11-10
  • Initial release [wichert]

Subscribe to package updates

Last updated May 25th, 2013

Download Stats

Last month:10

What does the lock icon mean?

Builds marked with a lock icon are only available via PyPM to users with a current ActivePython Business Edition subscription.

Need custom builds or support?

ActivePython Enterprise Edition guarantees priority access to technical support, indemnification, expert consulting and quality-assured language builds.

Plan on re-distributing ActivePython?

Get re-distribution rights and eliminate legal risks with ActivePython OEM Edition.