mirror of
https://github.com/getzola/zola
synced 2024-12-12 13:22:29 +00:00
Added documentation about relative image resizing and scaling of high-res (#2096)
This commit is contained in:
parent
692c690a22
commit
b965c89d12
3 changed files with 39 additions and 1 deletions
|
@ -179,7 +179,37 @@ Here is the result:
|
|||
</small>
|
||||
|
||||
|
||||
## Get image size
|
||||
## Get image size and relative resizing
|
||||
|
||||
Sometimes when building a gallery it is useful to know the dimensions of each asset. You can get this information with
|
||||
[get_image_metadata](@/documentation/templates/overview.md#get-image-metadata).
|
||||
|
||||
This can also be useful in combination with `resize_image()` to do a relative resizing. So we can create a relative image resizing function with the following shortcode named `resize_image_relative.html`:
|
||||
|
||||
```jinja2
|
||||
{% set mdata = get_image_metadata(path=path) %}
|
||||
{% set image = resize_image(path=path, width=(mdata.width * scale)|int, op="fit_width") %}
|
||||
<img src="{{ image.url }}" />
|
||||
```
|
||||
|
||||
It can be invoked from Markdown like this:
|
||||
|
||||
`resize_image_relative(..., scale=0.5)`
|
||||
|
||||
{{ resize_image_relative(path="documentation/content/image-processing/01-zola.png", scale=0.5) }}
|
||||
|
||||
## Creating scaled-down versions of high-resolution images
|
||||
|
||||
With the above, we can also create a shortcode that creates a 50% scaled-down version of a high-resolution image (e.g. screenshots taken on Retina Macs), along with the proper HTML5 `srcset` for the original image to be displayed on high-resolution / retina displays.
|
||||
|
||||
Consider the following shortcode named `high_res_image.html`:
|
||||
|
||||
```jinja2
|
||||
{% set mdata = get_image_metadata(path=path) %}
|
||||
{% set w = (mdata.width / 2) | int %}
|
||||
{% set h = (mdata.height / 2) | int %}
|
||||
{% set image = resize_image(path=path, width=w, height=h, op="fit_width") %}
|
||||
<img src="{{ image.url }}" srcset="/{{path}} 2x"/>
|
||||
```
|
||||
|
||||
{{ high_res_image(path="documentation/content/image-processing/08-example.jpg") }}
|
||||
|
|
5
docs/templates/shortcodes/high_res_image.html
vendored
Normal file
5
docs/templates/shortcodes/high_res_image.html
vendored
Normal file
|
@ -0,0 +1,5 @@
|
|||
{% set mdata = get_image_metadata(path=path) %}
|
||||
{% set w = (mdata.width / 2) | int %}
|
||||
{% set h = (mdata.height / 2) | int %}
|
||||
{% set image = resize_image(path=path, width=w, height=h, op="fit_width") %}
|
||||
<img src="{{ image.url }}" srcset="/{{path}} 2x"/>
|
3
docs/templates/shortcodes/resize_image_relative.html
vendored
Normal file
3
docs/templates/shortcodes/resize_image_relative.html
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
{% set mdata = get_image_metadata(path=path) %}
|
||||
{% set image = resize_image(path=path, width=(mdata.width * scale)|int, op="fit_width") %}
|
||||
<img src="{{ image.url }}" />
|
Loading…
Reference in a new issue