Forums / Setup & design / On-demand image variations

On-demand image variations

Author Message

Marc Boon

Tuesday 07 March 2006 5:18:51 am

I have a Image class containing 3 different variations of an image, each specified in a separate attribute of datatype image (original, medium, small). I don't want to use automatic scaling (variations are hand-cropped and scaled before uploading), so I removed the variations.
In image.ini.append.php:

[AliasSettings]
# store only original image
AliasList[]

In my class, only one image is required, so if the variation is not present, I need to create it on-the-fly as a scaled version of the required original. How do I do this?

Brian Gambill

Tuesday 07 March 2006 6:39:36 am

Asssuming the variations you need are sized consistently to one or two (or three or four) other sizes, put back the image aliases in image.ini and change the size(s) to what you desire.

Otherwise, I don't understand your problem. What I read is:
I don't want automatic scaling... then I want want scaling 'on the fly'

Does this mean you want scaling but only in the image when its sent to the user end, not stored on the server?

Marc Boon

Tuesday 07 March 2006 7:37:55 am

I want automatic scaling only as a fallback, when specific hand-created variations are not specified. In most cases they will be.

Marc Boon

Tuesday 07 March 2006 7:56:36 am

I could just specify two aliases (medium/small) to automatically create scaled copies of the original, and still have two extra image attributes in my class which can override the automatically scaled copies if they are specified. But in this case there would be also automatically created scaled versions of my custom medium/small images, giving a total of 9 images stored, where I only need 3. A waste of server space.

Related question: can you specify different image aliases for different classes or locations/sections?

Brian Gambill

Tuesday 07 March 2006 7:56:44 am

What method are you using to identify if the 'hand' variation is not present? Any image you upload will be called the 'original'. If you had a check box or something to indicate it’s wasn't the right size or un-edited, you could use that as a decision maker in your template code as whether to use the 'original' or one of the other variations (large, medium, small, custom).

Marc Boon

Tuesday 07 March 2006 8:09:43 am

Like I said in my original post, I have a custom Image class, which contains 3 image attributes. One (required) contains the large (original) image. The user can optionally upload two other images.
In the template, when a small image is needed, the code checks to see if this small image is specified by the user (attribute has content) if so, it will be displayed. If not, an automatically scaled version from the original will be displayed.

Brian Gambill

Tuesday 07 March 2006 8:13:11 am

I think I understand a little better. You want not just three different sizes of the same image, you want those different sizes to actually BE different images (not just scaled).

You can use different aliases depending on class/ section. This is all handled in the templates and how you call the images

THe following calls a medium size of particular attribute called picture which is the type image:

{attribute_view_gui attribute=$node.object.data_map.picture.content.data_map.image alignment=right image_class=medium}

So you custom class attribute name would replace 'picture'. You can use either/ both templates assigned to class/section and if statements to check for a variation.

old style:

{section show=$node.object.data_map.picture.content.is_empty|not}

Marc Boon

Tuesday 07 March 2006 8:25:09 am

"I think I understand a little better. You want not just three different sizes of the same image, you want those different sizes to actually BE different images (not just scaled)."

Right!
If some images need to be just scaled versions of the original, the user will not upload the variations manually, since then they can be scaled automatically. But in most cases, the variations are different images, like a detail of the original (cropped and possibly also scaled).

What you write about aliases I understand. But it implies that ALL images on the site are already scaled to all these variations. I wanted to know if you can specify how images are scaled *during upload*, depending on the containing class, or folder. So that you can have different types of variations depending on the class (or folder) that contains the images.

So, my question remains: can I create automatically scaled variations on the fly, without having ALL images automatically scaled during upload to all possible sizes ever needed (as specified in image.ini). I just want to avoid having 1000's of unused variations of images on my server.

eZ debug

Timing: Jan 18 2025 11:08:11
Script start
Timing: Jan 18 2025 11:08:11
Module start 'content'
Timing: Jan 18 2025 11:08:11
Module end 'content'
Timing: Jan 18 2025 11:08:12
Script end

Main resources:

Total runtime0.1612 sec
Peak memory usage2,048.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0059 588.8438180.8359
Module start 'content' 0.00590.0052 769.6797101.8828
Module end 'content' 0.01120.1499 871.5625530.2734
Script end 0.1611  1,401.8359 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00352.1755200.0002
Check MTime0.00140.8970200.0001
Mysql Total
Database connection0.00080.495810.0008
Mysqli_queries0.114671.12481410.0008
Looping result0.00130.81521390.0000
Template Total0.149692.810.1496
Template load0.00080.492610.0008
Template processing0.148892.296910.1488
Override
Cache load0.00050.325110.0005
Sytem overhead
Fetch class attribute can translate value0.00080.474510.0008
XML
Image XML parsing0.00020.126010.0002
General
dbfile0.00472.9321200.0002
String conversion0.00000.003830.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs