Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Modify brightness, contrast and saturation
Loading...
Loading...
Loading...
Color effects and filters
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Configure your Cloudimage instance
Making URL more semantic and SEO-friendly
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Securing your token, account and origin server
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Configure your website or web application to use Cloudimage
Loading...
Loading...
Plugin implementation for content management systems
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Step-by-step instructions how to set up Cloudimage with Shopify
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
We support all the major image formats, and a large number of more confidential ones.
We are obviously expanding our support to include any new significant formats being created. As of today, we have full support for the following origin formats and the ability to apply transformations for them:
Adobe Photoshop Document (PSD)
AVIF - AV1 image format
Bitmap (BMP)
Encapsulated PostScript (EPS)
Graphics Interchange Format (GIF)
High Efficiency Image File Format (HEIC)
Icon (ICO)
JPEG-compressed images
JPEG2000-compressed images
Portable Document Format (PDF)
Portable Network Graphics (PNG)
Scalable Vector Graphics (SVG)
Tag Image File Format (TIFF)
WebP image format
Resize and crop to achieve the desired width and height
Crops the image to specified dimensions (width and height) while keeping proportions and delivers the resulting image via CDN.
func=crop
Specifies which part of the image you wish to keep while cropping. If you omit the gravity option, central cropping is performed.
gravity=X
northwest
north
northeast
west
center | centre (default)
east
southwest
south
southeast
Do not upscale an image if target size is larger than the origin image
auto -
face -
smart -
X,Y -
Allow upscaling (default):
Prevent upscaling:
Crop by boundary coordinates
Allows to crop an image by providing the cropping area. It is useful when you want to crop a specific part of the image. To set the coordinates of the crop rectangle, use the tl_px and br_px operations or the X
and Y
Parameters are an alternative way to set the coordinates.
tl_px=X1,Y1
br_px=X2,Y2 X=X1 Y=Y1
Origin image: /docs/kids.jpg
/sample.li/kids.jpg?x=650&y=100
Positionable crop can be combined with all available resize functions - Width and height, Crop, Fit, Bound and Cover. This operation is performed after the positionable crop.
Cloudimage will solve your challenges with image resizing, transformation, and acceleration in the Cloud
Images slow down your website and mobile apps? Don't want to spend hours Photoshopping images for the web? Don't want to write complex image resizing automation scripts? Looking for Responsive images JS plugin? You've come to the right place.
We have documented the most common resizing functions here. Cloudimage supports many more, please contact us if you don't find your luck!
Cloudimage supports the chaining of various transformations and filters to edit and deliver your images. You can also overlay watermarks and optimize the compression controlling the image format and quality while taking into account the user browser's supported formats. This helps you achieve the best loading speed for your website or web application.
token
original_image_url
That's an easy one :)
Cloudimage's resizing servers, located in three data centers worldwide (Canada, France, and Singapore) will download your original image from an origin_image_url, transform it based on 50+ on-the-fly Image operations and Image filters parameters, and finally, display it on your website or mobile app through a rocket fast CDN.
Cloudimage is not a media storage service but rather acts as a media proxy downloading the origin (pristine) images and videos from your server or any storage container (S3, Google Cloud Storage, Azure Blob, ...) and optimizing them on-the-fly.
This page documents Cloudimage's image and video transformations APIs. If you are looking for a solution to upload and manage your media assets in one single source-of-truth, checkout Scaleflex's Digital Asset Management (DAM) solution. Its documentation is available here.
Crop operation focusing only on one face
Finds the most prominent face in the image and crops it to specified dimensions provided with the width and height parameters. If you however provide only one dimension, the other dimension will be chosen automatically to keep the aspect ratio of the face.
func=face
Sets margins around the face. You can set equal margins with face_margin=X or separate horizontal and vertical margins (face_margin=W,H).
face_margin=X|W,H
Crop operation which removes faces from the top of the image
Crops out the topmost part of an image if it contains a face.
To control the margin when cropping the face out, you can use the face_margin=Y operation where Y is a percentage of the face height. Its default value is 20. You can also use negative numbers if you would like to keep part of the face.
func=facehide
Crop by aspect ratio or aspect ratio range
Sets target aspect ratio or aspect ratio range when cropping. Aspect ratios can be set as decimal values (1.778) or ratios (16:9).
aspect_ratio=AR | ar=AR
aspect_ratio=AR1,AR2 | ar=AR1,AR2
If you provide only one dimension parameter (width or height) and aspect_ratio, the other dimension will be calculated. If you include both width and height in the URL, aspect_ratio is ignored.
If you provide only aspect_ratio and no dimensions (width or height), the image will be cropped without resizing.
You can specify a range of aspect ratio values, for example, aspect_ratio=4:3,16:9. Images that fall within this range, will not be cropped. Useful to avoid very wide or very tall images by cropping them to the closest aspect ratio.
Your Cloudimage customer token. Subscribe to get one. You can also for a custom token.
Image manipulation operations like width, height, crop, fit, rotate, trim. For a full list, see .
Use filters like contrast, pixellate, blur, greyscale and sharpen to apply different effects on your image. For a full list, see .
Cloudimage can place a watermark in your images if you want to protect them from copying, or tag them with a custom text. More details in the section.
Original aspect ratio (3:2 or 1.5): /sample.li/car1.jpg?w=400
Cropped to 1.8: /sample.li/car1.jpg?w=400&aspect_ratio=1.8
Original aspect ratio (1.323): /sample.li/frog.png
Cropped to 3:2 (1.5): /sample.li/frog.png?aspect_ratio=3:2
Original aspect ratio 1.5: /sample.li/car1.jpg?w=400
Aspect ratio range 1.5..2 (no crop needed): /sample.li/car1.jpg?w=400&aspect_ratio=1.5,2.0
Original aspect ratio 2.25:1 (2.25): /sample.li/kids.jpg?w=400
Aspect ratio range 3:2..2:1 (1.5..2): /sample.li/kids.jpg?w=400&aspect_ratio=3:2,2:1
Basic image resizing operations
Resizing operations enable the dynamic generation of image transformations to meet various web delivery use cases. Operations focus on the image size while Image filters allow to modify the image itself.
width=X
sets the image width to X pixels
height=X
sets the image height to X pixels
org_if_sml=1
prevents resizing if the target size is larger than the origin image
func=crop
behaviorsets crop resize function
gravity=X
defines the part of the image to be retained when cropping X = [north | south][east | west] | auto | X,Y
tl_px=X,Y
sets coordinates of the top left corner of the cropping rectangle
br_px=X,Y
sets coordinates of the bottom right corner of the cropping rectangle
func=face
crops the image automatically focusing on the most prominent face
func=fit
sets fit resize function
func=cropfit
sets crop or fit resize function depending on the origin and the desired dimensions
func=bound
sets bound resize function
func=boundmin
bounds the image to the larger dimension
func=cover
sets cover resize function (distorts image proportions)
flip=[h][v]
mirrors the image horizontally and/or vertically
r=X
rotates the image to X degrees (counterclockwise)
trim=X
trims any solid-color border (if present); X is the aggressiveness of the operation
radius=X
applies rounded corners and optionally fills the empty background with a color
When you specify width and height, original image proportions can be ignored or maintained. You may also choose to add padding to the image to fill the blank space.
Cloudimage supports the following resize function (operation func):
Keeps image proportions, cutting the image to fit the defined width and height; see Crop
This resizing function removes parts of the image and is the default behaviour when both width and height are defined. Read further for other resizing functions.
Resizes the image, keeping proportions and adding padding to satisfy the desired dimensions; see Fit
Performs either Cropor Fit based on image dimensions and transformation parameters; see Cropfit
This resizing function may remove parts of the image.
Fits image in a box of defined size without adding padding; see Bound
Resizes the image to the given width and height, ignoring original image proportions, thus distorting the image; see Cover
Automatic focal point detection
Chooses the most important image features and objects and sets the focal point on them when cropping.
gravity=smart
gravity=auto
gravity=face
Sets the crop focal point on the people in the image or on the most prominent features if no faces are detected. Useful for creating thumbnails from images with different aspect ratios.
If you prefer using the legacy automatic crop, just set the gravity operation to auto.
When using gravity=face, all images with one dominant face are focused on this face upon cropping. If there are many or no faces in the image, gravity falls back to auto.
Setting crop gravity with focal point coordinates
Allows to crop an image by defining the coordinates of the crop focal point. It is useful when you want to crop images where the coordinates of the point of interest are already known.
To set the coordinates of the focal point, use the gravity=X,Y operation where X and Y are the coordinates of the focal point (in pixels). Alternatively, you can set the coordinates as a percentage of the original image - gravity=Xp,Yp or gravity=xc,yc, where X,Y=0..100 and x,y=0..1.
gravity=X,Y
gravity=Xp,Yp|xc,yc
Fits the image in a box with padding when needed
Standard crop: /sample.li/business-portfolio.jpg?w=400&h=300
Face crop with automatic aspect ratio: /sample.li/classroom.jpg?h=240&func=face
650x500 origin image, cropped:
Same parameters, 400x250 origin image:
Original image:
gravity
gravity=X
X=[north|south][east|west]
sets the position of the image in the fit box
solid background
bg_color=X | bg_colour=X
X={hex color}|auto
defines a background color with a hex code, color name or automatically, based on the image palette
blurred background
bg_img_fit=1
sets blurred image background
bg_blur=X
applies Gaussian blur to the background image
bg_opacity=X
X=0..1
specifies background image opacity
bg_colorize=X | bg_colourise=X
defines a color to tint the background image
bg_gravity=X
X=[north|south][east|west]
defines the positioning of the background image within its container
image upscaling
fit_enlarge=1
allows upscaling smaller images to the desired dimensions (will result in inferior image resolution)
northwest
north
northeast
west
center | centre (default)
east
southwest
south
southeast
Solid background: /sample.li/hotel.jpg?w=400&h=245&func=fit&bg_color=000
Automatic solid background: /sample.li/frog.png?func=fit&w=400&h=220&bg_colour=auto
Blurred background: /sample.li/car1.jpg?w=400&h=320&func=fit&bg_img_fit=1&bg_opacity=0.75
Blurred background, tinted: /sample.li/boat.jpg?func=fit&w=400&h=330&bg_img_fit=1&bg_opacity=0.5&bg_colorize=red
Align Background image to right (east gravity): /sample.li/classroom.jpg?func=fit&width=600&height=600&q=70&bg_img_fit=1&bg_blur=15&bg_gravity=east&bg_colorize=lc000000&bg_opacity=0.5
Align Background image to left (west gravity): /sample.li/classroom.jpg?func=fit&width=600&height=600&q=70&bg_img_fit=1&bg_blur=15&bg_gravity=west&bg_colorize=lc000000&bg_opacity=0.5
No upscaling of smaller images (default):
/sample.li/castle_doc.jpg?w=600&h=245&func=fit&bg_color=113650
Resize with maximum size constraints (fit in a box)
Resizes to a given width and height box and keeps proportions. Similar to Fit but without adding padding. Delivers the resulting image via CDN.
func=bound
Delivers the optimal size based on device pixel-ratio
Allows you to deliver the proper image dimensions according to a defined device pixel ratio. This operation can help with conversion between device-independent pixels and CSS (reference) pixels. Useful in responsive image solutions using the srcset
HTML attribute. Allows positive values limited to 5.
dpr=X
Automatic crop or fit based on origin dimensions
Performs either Crop or Fit depending on the origin image and the desired transformation dimensions.
If the desired image is smaller than the original, the result is cropped to achieve the desired dimensions.
func=cropfit
If you include the Trim operation in the URL, the image will be trimmed first (if possible) and then either cropped or fitted to the desired size.
No dpr parameter (assumed dpr=1):
Device pixel ratio 1.75:
Original image (650x500 pixels):
Cropfit to 500x350:
Original image (400x250 pixels):
Cropfit to 500x350:
Original image:
Cropfit + trim:
Flip horizontally:
Flip both horizontally and vertically:
Transparent corners (default, if the formats supports transparency):
Solid color corners:
Original image: /sample.li/frog.png?w=400
Increased brightness: /sample.li/frog.png?w=400&bright=15
Decreased brightness: /sample.li/frog.png?w=400&bright=-10
Image trimming
Removes any single-color padding around the image if present.
The parameter does not specify the amount of border or frame to trim but rather how aggressive the trim algorithm should be. A bigger value of the parameter (e.g. 25) might trim part of the image. Typical values are between 0 and 10.
This allows you to use the same parameter values for all your images.
trim=X
Isolate the main object in the image and remove the background
bg_remove=1
Background removal automatically detects the foreground object and isolates it by removing the background of an image using advanced AI technology. It can help you create a solid or transparent background for your pictures. This can give your application or website an overall polished look. Moreover, product images with a clear-defined foreground can be indexed better in search engines which rely on AI classification.
Feel free to try the background removal algorithm with your own images on our AI demo page.
Colorize the image with an overlay
To create a color overlay by using colorize=X[,Y], where X is the color of the overlay (hex value or color name) and Y is the opacity (Y=0..1
, default 0.5
).
colorize=X[,Y] | colourise=X[,Y]
Color saturation correction
To adjust the color saturation, you can use the saturate=X filter and set the desired adjustment value (X= -100..100
). Negative values will decrease color saturation while positive ones will increase it.
saturate=X
Using saturate=-100 will remove all color information and convert the image to grayscale.
Duotone transform
Create a duotone effect by using duotone=C1,C2[,Y], where C1 and C2 are the colors for the duotone (hex value or color name) and Y is the opacity (Y=0..1
, default1
).
duotone=C1,C2[,Y]
Sepia tone
To apply a sepia effect to your images, you can use the sepia=1
parameter.
sepia=1
Original image:
Trimmed image:
Original image:
Trimmed image:
bright=X | f=bright:X
adjusts the brightness of the image
contrast=X | f=contrast:X
adjusts the contrast of the image
saturate=X | f=saturate:X
adjusts the saturation of the image
gray=1 | f=gray | grey=1 | f=grey
converts the image to a black and white one
colorize=X | colourise=X
applies a color overlay
pixelate=X | f=pixelate:X | pixellate=X | f=pixellate:X
pixelates the image into X-pixel-sized blocks
blur=X | f=blur:X
applies Gaussian blur
sharp=X | f=sharp:X
applies unsharp mask to sharpen the image
blur_faces=X
detects all faces in the image and applies blur to conceal them
Separate parameters: /sample.li/ny_doc.jpg?bright=15&contrast=30&gray=1
Concatenate into the f parameter: /sample.li/ny_doc.jpg?f=bright:15,contrast:30,gray
Original image: /sample.li/frog.png?w=400
Increased contrast: /sample.li/frog.png?w=400&contrast=30
Decreased contrast: /sample.li/frog.png?w=400&contrast=-10
Original image: /sample.li/frog.png?w=400
Color overlay: /sample.li/frog.png?w=400&colorize=red,0.85
Desaturate and color overlay: /sample.li/frog.png?w=400&saturate=-100&colorize=7af,0.6
Grayscale and color overlay: /sample.li/frog.png?w=400&gray=1&colorize=7af,0.6
Original image: /sample.li/frog.png?w=400
Increased saturation: /sample.li/frog.png?w=400&saturate=35
Desaturation: /sample.li/frog.png?w=400&saturate=-100
Grayscale: /sample.li/frog.png?w=400&gray=1
Original image:
By default, the image is desaturated first:
If you prefer, you can convert to grayscale instead:
60% opacity (0.6) of the filter:
Original image: /sample.li/paris.jpg?w=400
Grayscale image: /sample.li/paris.jpg?w=400&gray=1
Original image:
Sepia tone:
Original image:
You can combine any color adjustments and filters to achieve the desired artistic effects:
/sample.li/face.png?w=400&sepia=1&contrast=24&bright=-10&gray=1
Color inversion
To invert the colors of an image, use the invert=1 parameter.
invert=1
Compose image or text layers over the main image
Cloudimage can place a watermark on top of your images if you want to protect them from copying or tag them with a serial number or custom text. There are three types of watermarks - click on each one for more details.
You can overlay multiple watermarks by indexing the parameters in the URL wat[1]=1&wat[2]=1. The wat=1 parameter must be indexed and contain all watermarks to activate the feature.
All parameters without indices will be applied to all watermarks in the image.
?wat[1]=1&wat[2]=1&wat_scale[1]=50&wat_scale[2]=10&wat_opacity=0.5
In the above fragment, wat_opacity=0.5 will be applied to both watermarks.
Combining multiple watermark types is also possible.
?wat[1]=1&wat[2]=1&wat[3]=1&wat_url[2]=sample.li/Angular.png&wat_text[3]=text
In the above fragment, there are three watermarks. Watermark 2 is a dynamic watermark, watermark 3 is a text watermark, and watermark 1 is a static one.
Original image:
Faces blurred:
Only resize:
Resize and sharpen:
Apply the same image watermark to all the images you decide to watermark (e.g. your company's logo).
Specify the watermark in the Cloudimage URL to apply different watermarks to different images.
If you need to tag images, use the text watermark to dynamically embed text to the images you need tagged.
Original image:
Original image: /sample.li/ny_doc.jpg
Blur applied: /sample.li/ny_doc.jpg?blur=6
Original image: /sample.li/earth.jpg?w=400
Pixelate effect: /sample.li/earth.jpg?w=400&pixelate=8
Dynamic (defined in URL) image overlay
The dynamic watermark function allows you to specify the watermark image in the Cloudimage URL. This way, different watermarks can be used with different images.
use watermark
wat=1
(required) Activates the watermark function
watermark URL
wat_url=X
(required) The URL of the watermark image. Can be URL-encoded
watermark gravity
wat_gravity=X
X=[north|south][east|west]|center|
absolute|relative
Defines the position to "anchor" the watermark to
watermark scaling (relative to original watermark size)
wat_scale=X
X=0..100
Watermark image scaling defined in in percent of the watermark dimensions
watermark scaling (relative to output image size)
wat_scale=Xp
X=0..100p
Watermark image scaling defined in in percent of the output image dimensions
watermark padding
wat_pad=X[p][,Y[p]]
X/Y=0..100[p]
Adds padding from the anchoring point in pixels (X) or in percent (Xp)
watermark position
wat_pos=X[,Y]
sets the position in percent from the resized image; works only with wat_gravity=absolute and wat_gravity=relative
watermark opacity
wat_opacity=X
X=0..1
Defines watermark opacity
You can of course force a specific output format(s). More details can be found in the image formats section.
You can change the compression (output format and quality) of your image by using compression filters. You can use the compression filters alongside and .
Statically defined image overlay
This function will watermark selected images with the same watermark - an image set in the Cloudimage admin console. This is useful for placing your company logo, name, or other copyright information. If you would like to watermark different images with different watermarks, please refer to the Dynamic watermark section.
Log in to your Cloudimage admin console, navigate to Image Settings / Watermark, and upload your default watermark using the uploader.
use watermark
wat=1
(required) Activates the watermark function
watermark gravity
wat_gravity=X
X=[north|south][east|west]|center|
absolute|relative
Defines the position to "anchor" the watermark to
watermark scaling (relative to original watermark size)
wat_scale=X
X=0..100
Watermark image scaling defined in in percent of the watermark dimensions
watermark scaling (relative to output image size)
wat_scale=Xp
X=0..100p
Watermark image scaling defined in in percent of the output image dimensions
watermark padding
wat_pad=X[p][,Y[p]]
X/Y=0..100[p]
Adds padding from the anchoring point in pixels (X) or in percent (Xp)
watermark positon
wat_pos=X[,Y]
sets the position in percent from the resized image; works only with wat_gravity=absolute and wat_gravity=relative
watermark opacity
wat_opacity=X
X=0..1
Defines watermark opacity
To activate the watermark function, you need to include the wat=1 parameter.
The wat_gravity parameter allows you to define the position of the watermark. You can choose between "fixed" anchor points (east, northeast, north, northwest, west, southwest, south, southeast, and center) or define the exact position (relative, absolute).
When using "compass" point gravity, the wat_pad parameter defines the offset from the chosen position. The padding can be defined in pixels (wat_pad=X[,Y]) or in percent of output size (wat_pad=Xp[,Yp]). The padding is applied after scaling the final image and then it is compressed (see Compression) and delivered via CDN.
To set the exact position of the watermark, you can choose absolute or relative gravity and use the wat_pos parameter to define the position of the top left or center point of the watermark, respectively. The position is always defined in percent of the resized image dimensions.
The watermark can be scaled relative to the original watermark image (wat_scale=X) or relative to the output image (wat_scale=Xp).
Please note that the watermark cannot be larger than the image - if larger, it is always scaled down first to match the image dimensions. Then, the wat_scale parameter values are applied.
Absolute positioning - the top left corner of the watermark is position at 7% and 5% of the image width and height, respectively:
Supported output image formats
The JPEG compression format is suitable for delivering photographic images with minimal quality loss and a high compression rate. You can either choose the compression factor yourself or use Optipress - our Machine Learning algorithm, which will choose the best way to reduce JPEG file size minimizing perceptual quality loss.
Set format
force_format=jpg
forces using the JPEG image compression
Quality
q=X
X=0..100
the smaller the value of q, the more your image will be compressed. Be careful - the quality of the image will decrease as well.
Optipress
optipress=X
X=1..3
chooses the best compression approach maintaining visual quality via the Optipress algorithm
This format is a good choice for non-photographic images - flowcharts, graphs, screenshots, logos, etc. PNG also supports transparency.
Set format
force_format=png
forces using the PNG image compression
While the PNG format offers lossy compression only, Cloudimage can optimize the image before compression by reducing the number of colors or adding slight dithering (while preserving edges). This method usually leads to smaller file sizes for images visually indistinguishable from the original ones.
You can activate this feature in the Admin Console (Image Settings/Compression):
WebP is an image format maintained by Google and supported in certain browsers (mainly Chrome, Opera, and Chrome Android) which provides more aggressive compression techniques as JPG without noticeable quality degradation.
You can use the following parameters to control WebP compression quality:
Set format
force_format=webp
forces using the WebP image compression
Quality
q=X
X=0..100
the smaller the value of q, the more your image will be compressed. Be careful - the quality of the image will decrease as well.
Lossless
lossless=1
use lossless webp compression
By default, Cloudimage delivers the images in the format which will lead to the fastest delivery, while being supported by the requesting browser, as for exemple a WebP.
But sometimes WebP will be heavier than the original image (eg. a low resolution .JPG might be lighter than the same image .WEBP), so cloudimage will ignore the transformation process and provide the original format (when the original format is supported by the browser of course).
If you would like to systematically activate this function and always keep the format of the original image, you can use force_format=original
WebP format A modern format suitable for most images. Supports trasnparency and offers both lossy and lossless compression.
JPEG compression The most popular and widely-supported format. Used by digital cameras. Suitable for photographic images. Lossy compression only.
PNG format Image format with transperency support suitable for raster logos, charts, infographs, etc. Lossless compresison only.
Watermark scaled down to 45% of its original size (1178px), results in 530px watermark:
Watermark scaled relative to the output image dimensions (618px watermark):
q=85, filesize 204 kB: q=75, filesize 129 kB: q=65, filesize 102 kB:
Fonts available to use for text watermarks
Andale-Mono
LMMonoProp10-Oblique
LMSans9-Regular
Arial
LMMonoProp10-Regular
LMSansDemiCond10-Oblique
Arial-Black
LMMonoPropLt10-Bold
LMSansDemiCond10-Regular
Arial-Bold
LMMonoPropLt10-BoldOblique
LMSansQuot8-Bold
Arial-Bold-Italic
LMMonoPropLt10-Oblique
LMSansQuot8-BoldOblique
Arial-Italic
LMMonoPropLt10-Regular
LMSansQuot8-Oblique
Century-Schoolbook-L-Bold
LMMonoSlant10-Regular
LMSansQuot8-Regular
Century-Schoolbook-L-Bold-Italic
LMRoman10-Bold
Liberation-Mono
Century-Schoolbook-L-Italic
LMRoman10-BoldItalic
Liberation-Mono-Bold
Century-Schoolbook-L-Roman
LMRoman10-Italic
Liberation-Mono-Bold-Italic
Comic-Sans-MS
LMRoman10-Regular
Liberation-Mono-Italic
Comic-Sans-MS-Bold
LMRoman12-Bold
Liberation-Sans
Courier-New
LMRoman12-Italic
Liberation-Sans-Bold
Courier-New-Bold
LMRoman12-Regular
Liberation-Sans-Bold-Italic
Courier-New-Bold-Italic
LMRoman17-Regular
Liberation-Sans-Italic
Courier-New-Italic
LMRoman5-Bold
Liberation-Sans-Narrow
DejaVu-Sans
LMRoman5-Regular
Liberation-Sans-Narrow-Bold
DejaVu-Sans-Bold
LMRoman6-Bold
Liberation-Sans-Narrow-Bold-Italic
DejaVu-Sans-Mono
LMRoman6-Regular
Liberation-Sans-Narrow-Italic
DejaVu-Sans-Mono-Bold
LMRoman7-Bold
Liberation-Serif
DejaVu-Serif
LMRoman7-Italic
Liberation-Serif-Bold
DejaVu-Serif-Bold
LMRoman7-Regular
Liberation-Serif-Bold-Italic
FreeMono
LMRoman8-Bold
Liberation-Serif-Italic
FreeMono-Bold
LMRoman8-Italic
Nimbus-Mono-L
FreeMono-Bold-Oblique
LMRoman8-Regular
Nimbus-Mono-L-Bold
FreeMono-Oblique
LMRoman9-Bold
Nimbus-Mono-L-Bold-Oblique
FreeSans
LMRoman9-Italic
Nimbus-Mono-L-Regular-Oblique
FreeSans-Bold
LMRoman9-Regular
Nimbus-Roman-No9-L
FreeSans-Bold-Oblique
LMRomanCaps10-Oblique
Nimbus-Roman-No9-L-Medium
FreeSans-Oblique
LMRomanCaps10-Regular
Nimbus-Roman-No9-L-Medium-Italic
FreeSerif
LMRomanDemi10-Oblique
Nimbus-Roman-No9-L-Regular-Italic
FreeSerif-Bold
LMRomanDemi10-Regular
Nimbus-Sans-L
FreeSerif-Bold-Italic
LMRomanDunh10-Oblique
Nimbus-Sans-L-Bold
FreeSerif-Italic
LMRomanDunh10-Regular
Nimbus-Sans-L-Bold-Condensed
Georgia
LMRomanSlant10-Bold
Nimbus-Sans-L-Bold-Condensed-Italic
Georgia-Bold
LMRomanSlant10-Regular
Nimbus-Sans-L-Bold-Italic
Georgia-Bold-Italic
LMRomanSlant12-Regular
Nimbus-Sans-L-Regular-Condensed
Georgia-Italic
LMRomanSlant17-Regular
Nimbus-Sans-L-Regular-Condensed-Italic
Impact
LMRomanSlant8-Regular
Nimbus-Sans-L-Regular-Italic
LMMono10-Italic
LMRomanSlant9-Regular
Noto-Mono
LMMono10-Regular
LMRomanUnsl10-Regular
Times-New-Roman
LMMono12-Regular
LMSans10-Bold
Times-New-Roman-Bold
LMMono8-Regular
LMSans10-BoldOblique
Times-New-Roman-Bold-Italic
LMMono9-Regular
LMSans10-Oblique
Times-New-Roman-Italic
LMMonoCaps10-Oblique
LMSans10-Regular
Trebuchet-MS
LMMonoCaps10-Regular
LMSans12-Oblique
Trebuchet-MS-Bold
LMMonoLt10-Bold
LMSans12-Regular
Trebuchet-MS-Bold-Italic
LMMonoLt10-BoldOblique
LMSans17-Oblique
Trebuchet-MS-Italic
LMMonoLt10-Oblique
LMSans17-Regular
URW-Bookman-L-Demi-Bold
LMMonoLt10-Regular
LMSans8-Oblique
URW-Bookman-L-Demi-Bold-Italic
LMMonoLtCond10-Oblique
LMSans8-Regular
URW-Bookman-L-Light
LMMonoLtCond10-Regular
LMSans9-Oblique
URW-Bookman-L-Light-Italic
Minification of JS and CSS files
process=minify-css process=minify-js
Cloudimage supports on-the-fly optimization of CSS and JS content to further facilitate faster loading of your website or web application.
/sample.li/bootstrap.css?func=proxy&process=minify-css (152 kB minified vs. 192 kB original)
/sample.li/jquery.js?func=proxy&process=minify-js (111 kB minified vs. 219 kB original)
Apply text overlay
If you need to tag an image or add a reference number as an overlay, use the text watermark function.
use watermark
wat=1
(required) Activates the watermark function
watermark text
wat_text=X
(required) The text to be overlayed. Can be URL-encoded
watermark gravity
wat_gravity=X
X=[north|south][east|west]|center|
absolute|relative
Defines the position to "anchor" the watermark to
watermark padding
wat_pad=X[p][,Y[p]]
X/Y=0..100[p]
Adds padding from the anchoring point in pixels (X) or in percent (Xp)
watermark position
wat_pos=X[,Y]
sets the position in percent from the resized image; works only with wat_gravity=absolute and wat_gravity=relative
watermark opacity
wat_opacity=X
X=0..1
Defines watermark opacity
watermark font
wat_font=X
Choose the font family for the overlay
watermark color
wat_color=X | wat_colour=X
Sets the text color
watermark font size
wat_fontsize=X | wat_fontsize=Xmax
Sets the font size. If the Xmax syntax is used, the size is reduced if the text cannot fit in the image
ICC profiles and sRGB compression
By default, if the origin image has an embedded ICC profile, the image is converted to the sRGB color space, and the ICC profile is removed from the compressed image.
If you prefer to retain the original ICC profile instead of converting the image to sRGB, you can activate the Keep origin image ICC profile option in the admin panel (Image Settings -> Compression).
When using this option, to avoid embedding very large ICC profiles, you can set the maximum permitted ICC profile size (in kilobytes) along with setting the Convert ICC profile to sRGB if too large option.
Optimize filesize of SVG images
Cloudimage offers automatic optimization of Scalable Vector Graphics (SVG) files which can reduce the file size by up to 80% without visual appearance deterioration. This is possible since most SVG editors include unnecessary information which can be omitted. Moreover, most shapes in SVG files can be simplified.
Original (1543 bytes):
Static file acceleration
func=proxy
Cloudimage offers you the option to deliver any file, including non-processable files - static content like JS or CSS files, via our Content Delivery Network.
By default, all URLs are regarded as images. To deliver a non-image file, you have to use the func=proxy option:
/sample.li/bootstrap.css?func=proxy
Cloudimage can automatically use the proxy function for all files that don't have an image file extension. This however will require all your images to have proper file extensions. If you prefer this behavior, you can switch it on in your Admin Console (Image Settings / Compression / Enable static Content acceleration):
Machine learning based image compression
Different images compressed with the same compression parameters may result in different perceptive quality. Moreover, the same image in different sizes may require different compression strategies to achieve maximum size gain without visible quality loss.
To overcome this, you can use our Optipress JPEG compression algorithm.
Optipress finds out the best JPG compression approach by analyzing specific image features and current compression parameters.
A Machine Learning model determines the best compression strategy for this image.
Quality is then evaluated based on a simulation model of the Human Visual System to achieve optimum compression without perceptive quality deterioration.
By using Optipress, you can get the most out of the JPEG compression format.
optipress=1
most conservative setting; image quality is prioritised
optipress=2
balanced setting
optipress=3
most aggressive setting; optimised for smaller file size
Convert a specific page from a PDF document to an image
doc_page=X
When you provide a link to a PDF file, the first page is converted to an image and delivered via CDN. You can use all available resizing operations, image filters, watermarking capabilities, and image compression formats. To convert a specific page of the PDF document, use the doc_page=X option:
Text too long for the image:
Text size limit set with wat_fontsize=20max:
Compressed SVG (221 bytes):
q=85, 543 kB: optipress=3, 347 kB:
q=85, 246 kB: optipress=3, 150 kB:
Using a single origin server for your files
To make your Cloudimage URLs shorter and improve SEO, you can configure an origin prefix. For example, if your images are stored at the URL https://hello.s3.aws.com/
, you can set up prefix URL:
When you use:
//token.cloudimg.io/photos/paris.jpg?width=800
Cloudimage will search the origin image at the URL:
//hello.s3.aws.com/photos/paris.jpg
By using the origin prefix, you can avoid exposing the URL of your media to users.
Use short pre-defined aliases for different origin servers
With aliases, you can easily "mount" src0
to static.mycompany.com/bucket/img
.
Log in to your Cloudimage admin console, navigate to Image settings, and scroll down to Aliases. Configure up to 10 aliases:
Due to the specific way aliases are matched, it is required to use only specific aliases that are not contained in part of other alias strings.
Example: If you define an alias _demo_one_
then you should not have:
_demo_
_demo_one_two_
_my_demo_one_
As those would all be matched according to the first overlap (in this example, _demo_
). An easy way to overcome this is by both prefixing and suffixing aliases with double underscores.
Without Alias
With Aliases
Save combinations of commonly used parameters in presets
p=X
If you wish to apply the same transformations on many images, you can define presets and apply transformations only using the preset name (X).
You can define your presets in the admin panel, Image Settings / Presets.
Here are a couple of images using the sample presets shown above.
You can use additional operations together with a preset. Here is an example:
Here are a couple of examples of how you can extend the presets from above:
The Origin URL prefix will apply to all Cloudimage transformations for your token. Make sure that all your origin images are served from the Origin URL prefix domain. Should you have multiple source domains, then please use instead.
If your origin server needs authentication, please refer to the section.
Aliases are a very easy way to hide parts of your URLs: They can be useful if your images come from different image repositories (for example: https://static.mycompany.com/bucket/img
) and you do not wish these repositories to be publicly shown in your code. If you use only one repository for all your images, you can alternatively use .
All aliases have to be prefixed and suffixed by underscores. Make sure there are no leading or trailing slashes. Please note that all aliases have to be unique for your account - aliases set in the alias section cannot be used in the Storage sections (see ).
All and can be included in a preset, as well as and parameters.
gallery_thumb
w=250&h=250&gray=1
gallery_medium
w=450&h=300&radius=10&force_format=jpeg&q=85
gallery_large
w=1200&force_format=jpeg&optipress=2&wat=1&wat_gravity=northwest&wat_scale=60&wat_pad=20&wat_opacity=0.4
red_ref_number
w=400&h=200&wat=1&wat_gravity=northeast&wat_pad=10&wat_font=Arial-Black&wat_fontsize=18&wat_colour=660000
Using third-party origin file storage
You can set up external storage in the Storage section in the admin panel by using the Connect External Storage button.
Short clip processing and delivery for websites and web applications
Please contact the support team to activate the video feature for your token.
Cloudimage offers on-the-fly video processing with delivery via CDN using the Cloudimage URL for seamless integration. This feature is suited for short clips for websites and web applications such as hero videos or product videos.
Input files are limited to 500 MB, 4k resolution and maximum 60 seconds length. For longer videos, only the first minute will be optimized and delivered, resulting in a trimmed video.
//token.cloudimg.io/original_image_url.mp4?w=600&format=auto
Cloudimage can download your origin images/files from any server or storage bucket over HTTP/HTTPS/FTP. Setting up an external storage is optional and you can use Cloudimage with your origin image URLs as shown in the introduction - .
If the images are not publicly available, you have to configure your storage containers and set authentication parameters. If you are filtering access to your image storage by IP addresses, to get help with configuring for Cloudimage to request origin images over the specified proxy and have all Cloudimage requests coming from the same IP address.
You can set up an , , or any generic HTTP-based storage (see .
w
>100
Sets the target video width
h
>100
Sets the target video height
func
crop
(default) | fit
| cropfit
| bound
| boundmin
| cover
Sets the resize function if both width and height parameters are provided
bg_color
hex color code / color name
Background (padding) color (for use with func=fit)
bg_img_fit
1
Use blurred version of the video for background / padding (for use with func=fit)
format
auto
(default) | mp4
| webm
| h264.mp4
| h265.mp4
| vp9.webm
Defines the video format
bitrate
10k..20000k
| 1m..20m
(ex.300k, 2m
)
Sets the compression bitrate (in kilobits or megabits per second)
Simple resize: /sample.li/waterfall-hd.mp4?w=400
Crop function: /sample.li/waterfall-hd.mp4?w=400&h=300
Fit function with blurred background: /sample.li/waterfall-hd.mp4?w=400&h=300&func=fit&bg_img_fit=1
Sets the compression bitrate in kilobits or megabits per second. /sample.li/waterfall-hd.mp4?bitrate=1000k
Public or authenticated GCP storage
If your images are stored in a bucket named mysamplebucket and you can access image.jpg at the following URL:
//www.googleapis.com/upload/storage/v1/b/mysamplebucket/o/image.jpg
You should enter the data as follows:
All aliases have to be prefixed and suffixed by underscores. Please note that all aliases have to be unique for your account - aliases set in the storage sections cannot be used in the alias section.
Your storage bucket is now accessible by using the alias entered in the Cloudimage Alias field:
//your-token.cloudimg.io/__googlecloud__/image.jpg
If your Google Cloud bucket requires authentication:
You need to generate an Authentication JSON file using the guide in the Google Cloud documentation - https://cloud.google.com/docs/authentication/getting-started
You will be provided with a JSON file to be saved on your computer
Copy the contents of this file and paste it into the field that appears after pressing "AUTH KEY" in the storage settings
Public or authenticated Amazon S3 bucket
If your images are stored at a bucket named mysamplebucket at the eu-central-1 region and you can access image.jpg at the following URL:
//s3.eu-central-1.amazonaws.com/mysamplebucket/image.jpg
You should enter the data as follows:
All aliases have to be prefixed and suffixed by underscores. Please note that all aliases have to be unique for your account - aliases set in the storage sections cannot be used in the Aliases section.
Your storage container is now accessible by using the alias entered in the Cloudimage Alias field:
//your-token.cloudimg.io/__amazonaws__/image.jpg
If your S3 bucket requires authentication, you can enter your access key ID and secret access key:
Public or authenticated generic HTTP storage
If your images are stored at URL https://mystorage.example.com
and you can access image.jpg at the following URL:
//mystorage.example.com/image.jpg
You should enter the data as follows:
All aliases have to be prefixed and suffixed by underscores. Please note that all aliases have to be unique for your account - aliases set in the storage sections cannot be used in the alias section.
Your storage is now accessible by using the alias entered in the Cloudimage Alias field:
//your-token.cloudimg.io/__ownstorage__/image.jpg
If your storage requires authentication, you can enter your username and password:
Protect your Cloudimage token from abuse
Apply transformation rules based on url pattern
Cloudimage lets you define transformation rules based on image path and filename pattern matching.
All Image operations and Image filters can be included in a rule, as well as Image watermarking and Image compression parameters.
You can define your presets in the admin panel, Image Settings / Rules.
-avatar.jpg
func=crop&w=300&h=300&radius=max
Here is an image using the rules from above:
You can add additional operations together with a preset. If an operation or a filter already exists, the value provided in the URL will take precedence over the one in the rule. Here is an example:
-avatar.jpg
func=crop&w=300&h=300&radius=max
Adding more parameters or overriding some of the parameters from above:
Public or authenticated Microsoft Azure Blob
If your images are stored at a blob with account my_blob in a container named my_container and you can access image.jpg at the following URL:
//my_blob.blob.core.windows.net/my_container/image.jpg
You should enter the data as follows:
All aliases have to be prefixed and suffixed by underscores. Please note that all aliases have to be unique for your account - aliases set in the storage sections cannot be used in the alias section.
Your storage container is now accessible by using the alias enter in the Cloudimage Alias field:
//your-token.cloudimg.io/__my-public-blob__/image.jpg
If your Azure Blob container requires authentication, you have to enter your SAS token (found in your Azure panel) in the respective field:
Please keep in mind that the SAS token has an expiration date and you have to generate a new one and update it before it expires. Otherwise, our servers will not be able to fetch your media from the storage.
Allow fetching images only from a pre-defined list of origins
As a reminder, a Cloudimage URL looks like this:
//token.cloudimg.io/original_image_url?operations&filters
By default, images from any origin domains can be resized by Cloudimage. The storage and traffic used by these images will count toward your plan’s allowance. In the Cloudimage admin console, you can restrict the list of origin server URLs your token can transform images from.
Please note that when you whitelist eg. sample.li
, this will also whitelist all its subdomains sub1.sample.li
, www.sample.li
, along with any recursive (sub...)sub.domain from the listed one.
When adding a domain to the whitelist, do not include http://
or https://
.
This Cloudimage URL works (the sample.li domain is whitelisted):
If the domain is not in your whitelisted domains list, the request will fail. In this example, pbs.twimg.com
is not whitelisted, so the request is blocked.
Specify which domains your Cloudimage token can download original images from. You can limit the list to a few domains that you own to make sure no one uses your token on his or her URLs.
Sign your Cloudimage URLs with an SHA hash to prevent someone else from using your Cloudimage token.
With this feature, you can sign only part of the url which will allow you to add more parameters to the URL while protecting the sealed ones.
If you are using and you have Domain whitelisting enabled, you have to include all aliases in the whitelisted domain list.
Log in to your and navigate to Image settings / tab Domains. Scroll down to Whitelisted domains. Then configure your original image domains / S3 buckets.
By default, Cloudimage does not enforce the domain whitelist when delivering. If you would like to restrict delivering static content to whitelisted domains only, you can enable the Honor whitelist when delivering static content option in the Admin console.
Multi-factor authentication to the Cloudimage Console
The access to the Cloudimage administration Console supports SSO over SAMLv2. Cloudimage officially supports several Identity Providers (IDPs) and can integrate with any IDP that speaks SAML 2.0. You can integrate Cloudimage as a Service Provider (SP) with your IDP to allow your Cloudimage administrators to log in to the Console with a federated account and enjoy SSO.
Copy the ACS URL / Consumer URL and Entity ID / Audience ID or download the Service Provider XML from the link provided. These values are needed for configuring Cloudimage as a Service Provider or Relying Party Trust (ADFS) in your IDP.
Within your Identity Provider, add a Service Provider (generic term, Ping Federate), Application (OKTA), or Relying Party Trust (ADFS) using the information gathered in the previous step.
Make sure the IDP is returning the user's email address as NameID in the SAML assertion with the format emailAddress (see note below for ADFS).
Go back to the Cloudimage Console to finish the configuration.
If you are using ADFS as IDP, you will need to configure the following two Issuance Transform Rules for the Relying Party Trust:
Fill in the Identity Provider section:
Entity ID: the entity ID from your IDP as per the IDP's metadata.xml.
SSO Target URL: IDP single sign-on URL.
SAML Single Logout Service URL: IDP single sign-out URL (usually the same as SSO Target URL).
Signing Certificate: IDP's signing certificate is log inas per the IDP's metadata.xml. This certificate is used by Cloudimage to verify the SAML assertion's signature returned by the IDP.
Using your Cloudimage admin account's email from your company, try to log in.
Enjoy SSO and additional security!
Protect your Cloudimage URLs from tampering
To prevent URL tampering and protect your token, every Cloudimage URL can be secured with an SHA-1 HMAC signature.
Please be aware that when the URL signature is activated for your token, all Cloudimage URLs which are not signed properly will cease to work.
The signature is calculated as follows:
The syntax to process an image is:
//token.cloudimg.io/original_image_url?operations&filters&ci_sign=Signature
Because the Salt is a shared secret between you and Cloudimage, only you will be able to calculate the signature of your images.
Before activating the URL signature, please make sure that all Cloudimage URLs contain the proper signature.
To activate this feature, you need to navigate to Image Settings / Security and activate URL security toggle.
In the Add Security modal, you need to choose URL Signature and place a string you will be using as salt when generating the URL signature.
Protect your origin with custom request headers
Cloudimage allows you to set up one or many global headers which are sent to the origin on every request.
You need to enter the name
and value
of the header(s) to send. All these headers will be automatically sent for each request made with your token which allows you to set up your origin to accept only requests containing these headers.
Secure part of your Cloudimage URLs against tampering
To prevent your customer from removing certain parameters, you can seal them. For example, if you don't want your users to get the image without a watermark or a certain filter, you can use the URL sealing feature. This system is similar to the URL signature feature but it is only sealing the ci_eqs
parameters and allows you to add more filters and operations to the URL without re-generating the signature. This method is compatible with the Responsive images JS plugin.
Please be aware that when URL sealing is activated for your token, all Cloudimage URLs that are not signed properly will cease to work.
The signature is calculated as follows:
Signature = sha1('URI' + 'ci_eqs' + 'Salt') where URI = original_image_url and ci_eqs = value of the content of ci_eqs
query string
The syntax to process an image is:
//token.cloudimg.io/original_image_url?ci_eqs=Sealed_parameters&ci_seal=Signature
The Salt string is a shared secret between you and Cloudimage and only you will be able to calculate the signature of your images.
Before activating URL sealing, please make sure that all Cloudimage URLs contain the proper signatures (see the Usage section below).
To activate this feature, you need to navigate to Image Settings / Security and activate the URL security toggle.
In the Add Security modal, you need to choose URL Sealing and place a string you will be using as salt when generating the sealed parameter signature.
To watermark an image at the URL sample.li/birds.jpg
with query string wat=1&wat_url=http://sample.li/louis-vuitton-logo-white.png&wat_scale=45&wat_gravity=southwest&wat_pad=15
, you need to first base64-encode the query string:
becomes
d2F0PTEmd2F0X3VybD1odHRwOi8vc2FtcGxlLmxpL2xvdWlzLXZ1aXR0b24tbG9nby13aGl0ZS5wbmcmd2F0X3NjYWxlPTQ1JndhdF9ncmF2aXR5PXNvdXRod2VzdCZ3YXRfcGFkPTE1
The signature has to be created by sha1-hashing the string 'URI' + 'ci_eqs' + 'Salt':
The final signature is:
a355cce069fbfb18a4c39113067bf626ead2ebab
//token.cloudimg.io/original_image_url?ci_eqs=Sealed_parameters&ci_seal=Signature
The final URL becomes:
You can use the URL as is or append more parameters to the query string:
Any parameters that are included in the sealed portion cannot be overwritten in the URL. For example, if a watermark is activated with wat=1 and sealed, appending wat=0 in the URL will not remove the watermark:
Direct implementation using the Cloudimage URL API
If your Web application does not use a CMS (Wordpress, Drupal, ...), e-commerce platform (Prestashop, Magento, ...), or development framework (React, Angular, Django, ...), then you need to adapt your image URLs in your HTML <img>
tags.
For example, if your origin image is available at the following URL::
http://sample.li/flat.jpg
Then you need to adapt it to be:
//token.cloudimg.io/http://sample.li/flat.jpg?operations&filters&watermarks
Where:
token: your Cloudimage token you obtain after registering for a Cloudimage account;
In your code, this URL can be used as a normal image in your <img>
elements:
If you have implemented responsive design with the HTML <picture>
and <srcset>
elements, then you need to change every <srcset>
:
Becomes:
ci_url_encoded=1
If a resource is versioned or dynamically generated using query strings, or the filename contains unsupported or reserved characters, you will need to url-encode the URL of the resource. In this case, you need to add the ci_url_encoded=1 parameter to the Cloudimage URL.
For example, in the origin below, the ?w=22 query string is part of the static resource (origin image):
To construct a Cloudimage URL from it, the resource is URL-encoded and the width operation can be now used correctly:
When using ci_url_encoded=1 to encode URLs with space in the filename, please consider the example: Image: https://freeaccessdemo.blob.core.windows.net/myfiles/Image with space in the name.jpg
Need to be encoded according to RFC-3986 (percent-encoding):
And if for example, we have extra values added to the origin resource like v=13, the final Cloudimage URL will look like this:
The following approach can be used in this case:
operations: the resizing operation(s) as listed under ;
filters: the filter transformation(s) as listed under ;
watermarks: any image or text overlay(s) as listed under .
You need to define the image size with operations1
and operations2
to deliver the lightest possible image. If you want Cloudimage to do the job for you and define the optimal size based on your container width, then look at our , and plugins.
Javascript implementation for pixel perfect design
Responsive images adapt the image size according to the screen size of the end user, thereby allowing your website or mobile app to load faster across various screen sizes. For example, on an iPhone, Cloudimage will deliver smaller images than it would on a 15" computer screen, thus accelerating the page loading time.
Managing a responsive site manually can be tedious, especially for a site with more than 20-30 images. Therefore, the Cloudimage team has developed a JS plugin to automate everything for you. Check it out here as well as a demo.
The Cloudimage JS lib will adapt all your URLs automatically and offers built-in Responsive Design, Lazyloading, and many more features to make your website responsive and fast as well as add nice loading effects to your images
Start up the Spryker shop and run:
To get the package running, register the "Scaleflex" namespace into the config_default.php in the KernelConstants::CORE_NAMESPACES
Set these constants in the config, where it is needed. the BaseUrl and the ignoredUrlPaths need to be set according to the use case.
Register the Twig plugin in the Pyz\Yves\Twig\TwigDependencyProvider.php
Example
Use the TwigFilter for the images. Here is an example of how to extend the Pyz\Yves\ShopUi\Theme\default\components\molecules\lazy-image.twig. Everywhere this molecule will use Cloudimage and apply a grey filter.
How to use the plugin
Vanilla JS:
React:
Angular:
Vue.js:
Cloudimage documentation for the operations:
Cloudimage documentation for the filters:
Cloudimage Kontent.ai connector
You need to have a Kontent CMS setup. https://kontent.ai/
Content model (left hand side) > Create new > Custom element (right hand side). You will then have the below view.
Hosted code URL: https://scaleflex.cloudimg.io/v7/plugins/cloudimage-kontent/cloudimage.html?func=proxy
Parameters are the information that Kontent-Cloudimage needs to accelerate your images. See below:
note: "mgmtApiKey" is obtained from:
Content & asset (left hand side) > Create new > Chose type: Cloudimage. Chose add/remove some images, publish. You will then have the below view.
After publishing, it will look like below. The URLs are Cloudimage accelerated.
Here, you can find a tutorial on how to set up a preview: https://kontent.ai/learn/tutorials/develop-apps/build-strong-foundation/set-up-preview/
Go to Settings > API Keys. For this, you will definitely need your Project ID. You may also need your API Key (depends on what you want to do, but for simple things Project ID is enough).
Write a client app that utilizes the Delivery API
Recall that Kontent have 3 set of APIs that you can interact with
Delivery APIs in plain HTTPS form can be taken from https://kontent.ai/learn/tutorials/develop-apps/get-started/postman-collection/ , imported into POSTMAN
For the 3 content items that comes out of the box, Kontent already have an example client app, which we can imitate.
This example app was made by using React JS https://github.com/Kentico/kontent-sample-app-react
Hosted on Github Pages: https://kentico.github.io/kontent-sample-app-preview-react/{restof the URL}
After writing and hosting your client app, go to Settings > Preview URLs and define your Preview URL formats.
See how Kontent defined their preview URLS for their example app
Codename
, URLSlug
& ItemId
are obtained as follows:
Once you done all the above, you can preview by clicking Preview
https://scaleflex.zendesk.com/hc/en-gb/requests/new or hello@scaleflex.com
Magento plugin
Cloudimage can be implemented to accelerate Magento shops in 2 modes:
Simple configuration change in Magento settings
JPEG optimization WebP delivery CDN acceleration
Basic + Responsive images
Cloudimage Drupal module
You can install the Cloudimage module from Github or by using Packagist.
Step 1: Download the latest version Download Latest release of the Module
Step 2: Extract the zip file at location "/modules"
Step 3: In Admin go to Extend -> find Cloudimage by Scaleflex -> Install
Step 1: Run "composer require 'drupal/cloudimage_by_scaleflex:^1.0'"
Step 2: In Admin go to Extend -> find Cloudimage by Scaleflex -> Install
Activation: Enable/Disable the module
Standard Mode: Replace image URLs not using any Javascript or Javascript library.
Token or CNAME: Please enter your cloudimage token here (eg: abcdefgh), or your complete CNAME (eg. media.company.com) if the configuration is already validated in your Cloudimage Admin.
Use origin URL: If enabled, the module will only add query parameters to the image source URL without prefixing it with {token}.cloudimg.io
.
Lazy Load: If enabled, only images close to the current viewpoint will be loaded.
Ignore SVG Size: If enabled, the module will ignore the image size node in the SVG file.
Image Size Attributes: Used to calculate width and height of images
Prevent Image Upsize: If you set Maximum "Pixel ratio" equal to 2, but some of your assets does not have min retina size(at least 2560x960), please enable this to prevent image resized. By default, yes.
Image Quality: The smaller the value, the more your image will be compressed. Careful — the quality of the image will decrease as well. By default, 90.
Maximum Pixel Ratio: The maximum pixel ratio of the image. By default, 2.
Remove V7: If enabled, the module will remove the "/v7" part in URL format. Activate for token created after October 20th 2021.
Custom JS Function: The valid js function starting with { and finishing with }
Custom Library Options: Modifies the library URL (to add transformations)
Cloudimage Contentful plugin
You need to have a Contentful account. Contentful is 100% Cloud Native, so you have to sign up for a hosted CMS at https://be.contentful.com
You’ll get :
Find it here https://www.contentful.com/marketplace/ and install it.
Or click "Install now" on https://www.contentful.com/marketplace/app/scaleflex-cloudimage/
Then save and install.
Absolutely important: The Field ID must be "cloudimage".
By doing the above, you will associate the Cloudimage field (the field that you named Cloudimage) to the Cloudimage App. Recall the warning message you saw during the app configuration stage "There are no content types with ..."? By doing the above, that will no longer be an issue.
Now you can create a content item of Cloudimage type.
You can add and remove images.
Cloudimage will optimize those images in the background. (If you inspect in developer console, you will see the call to its infrastructure)
Magento simple implementation
This simple and fast implementation in Magento 2 enables JPEG optimization, WebP compression and CDN delivery of your images.
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
First, you need to log in to your Magento 2 website admin
On the Admin sidebar, go to Stores > Settings > Configuration.
Navigate to the settings page - from the left panel, in the General group, choose Web.
Then, you need to set up the Base URLs.
It is important to set this prefix in both - Base URL for User Media Files and Secure Base URL for User Media Files.
In Base URL for User Media Files in Base URLs and Base URLs (Secure) add the following value, replacing your token: https://<token>.cloudimg.io/{{secure_base_url}}pub/media/
For example, if your website is https://sfxmagento.site
, and your token is demo
, the final URL address should be: https://demo.cloudimg.io/https://sfxmagento.site/pub/media/
You can also use your own domain instead of {token}.cloudmg.io via CNAME records. Please contact us and an engineer will help setting it up.
When complete, do not forget to click Save Config.
On the Admin sidebar, go to System > Tools > Cache Management and Flush the cache of Magento.
Magento’s cache management system is an easy way to improve the performance of your site. Whenever a cache needs to be refreshed, a notice appears at the top of the workspace to guide you through the process. Find additional information and tips in this Magento tutorial for cache management.
Please ensure that you are properly delivering static content via the CDN.
You can now modify your template to resize your images with us.
Cloudimage Content Transformation & Acceleration in Magento
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
To be able to install the module by Composer, you need to get a copy of the module on the Magento Marketplace, or directly from Github.
Enable and install module in Magento:
Activate the module and enter your Cloudimage token in the module configuration in Magento admin interface: Stores / Configuration / Cloudimage by Scaleflex / Cloudimage Responsive
:
Use origin URL
If enabled, the module will only add query parameters to the image source URL without prefixing it with {token}.cloudimg.io. This is required if you use a dedicated subdomain for delivering your images (media) in Magento. You will need to enable a custom CNAME in Cloudimage.
Ignore Image Size Node
Useful for improving compatibility with some themes.
Ignore Image Size Style
Useful for improving compatibility with some themes.
Lazy Loading
If enabled, images will be lazy-loaded for better loading times and user experience.
This setting is for advanced users only and allows to inject a custom JS function into the Magento templates in order to support some specific Magento templates. Feel free to contact us in order to get the custom JS function to address issues with your specific template.
Inject Custom JS function
If enabled, you will be able to customize the JS function used to get the DOM information dynamically.
Custom JS function
The JS function to customize Cloudimage library.
Once activated, the Cloudimage Responsive module will replace your template's classic image tag elements on-the-fly. This functionality is 100% compatible with the Magento Luma theme.
In the case of a personalized template, please consult the Manual integration in Magento templates section in the Cloudimage plugin Github page.
Cloudimage Opencart plugin
The Cloudimage Opencart Plugin will automatically adapt the image URLs in your Opencart site to deliver your images rocket fast over the Cloudimage multi-CDN infrastructure. You only need to register with Cloudimage and install the plugin in your Opencart Admin.
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
To get the plugin, you need to open Opencart Extension Marketplace.
Then, search for "Cloudimage" in the search bar.
Select the Cloudimage by Scaleflex plugin and click on Download. The Download button will be available on the right side. This will download the .zip file.
First, you need to log in to your Opencart Admin:
Then, navigate to Extension->Installer.
Click on "Upload" and upload the .zip file that you downloaded in the previous step:
Navigate to Extensions->Modifications and select refresh in the Modification panel. Refresh button will be available on the top right corner as shown below:
Navigate to Extensions->Extensions->Modules.
Select Cloudimage from the list of modules and click on Edit.
Enable the plugin and enter Cloudimage Token or CNAME
You need to enter your Cloudimage account token which you have received upon account creation (step 1).If you need a CNAME please contact our sales team.
After you enter your token and save the changes, the plugin will start to deliver your images via Cloudimage.
Remove v7 from URL
If your token/CNAME was created after 20th October 2021 you need to tick this option.This option will remove the "v7" part from image URLs.
Enable debug image overlays
For troubleshooting purposes to view details about resizing and compression. Note:This will print information over your images.
Cloudimage image output quality
To increase or decrease the quality of images delivered by cloudimage.Slide to the right to increase quality.
Javascript Mode
When Javascript Mode is active, make sure that no other module is overwriting the plugin's delivery with "ci-src" image source.
Implement Cloudimage on Prestashop 1.6+
This simple and fast implementation in Prestashop leverages JPEG optimisation, WebP compression and CDN delivery of your images. Contact us if you want to use Cloudimage at its full extend and also resize, watermark, transform and leverage responsive images on your Prestashop store.
Please note that to use your Cloudimage account with Prestashop, you need to use the Origin URL prefix function. This means that you will be able to use your Cloudimage token for delivering images only from your Prestashop site.
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
There are two basic configuration steps:
First, you need to contact us at hello@cloudimage.io and let us know that you would like to use your Cloudimage token with Prestashop. We will lock your account to the v7 API of Cloudimage. Note: This step is required only for tokens created before November 1, 2021.
Then, you need to set up the Origin URL prefix in your Cloudimage admin to your Prestashop domain. By doing this, your token will fetch images only from your Prestashop site.
Add in Media Server #1, the Cloudimage domain and click to Save.
Please ensure that you are properly delivering static content via the CDN.
This simple and fast implementation in Prestashop leverages JPEG optimisation, WebP compression and CDN delivery of your images. Contact us if you want to use Cloudimage at its full extent and also resize, watermark, transform and leverage responsive images on your Prestashop store.
Cloudimage Prestashop module
The Cloudimage Prestashop Module will automatically adapt the image URLs in your Prestashop Theme to deliver your images rocket fast over the Cloudimage multi-CDN infrastructure. You only need to register with Cloudimage and install the plugin in your Prestashop Admin.
First, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
Download the latest version Download Latest release of Module
Unzip the file and change the folder name to "cloudimage"
Zip the file with the name "cloudimage.zip"
In Admin go to Modules/Module Manager -> Upload the Zipped file
In Admin go to Modules/Module Catalog search for "Clouldimage by Scaleflex"
Click "Install"
Go to Modules/Module Manager -> Other Section -> Click on Configure on "Cloudimage by Scaleflex"
Update configuration and activate the Module, then your site is ready to go. (Please clear the Cache)
Activation: Enable/Disable the module
Cloudimage API Key: Your Cloudimage Token
Prerender: If enabled, the plugin will disable JS Responsive and Change URL to {token}.cloudimg.io/{origin_url}
Auto Base URL Image: If enabled, Production with SSL only, The Plugin auto add base url to some missing Base URL Images
Use origin URL: If enabled, the plugin will only add query parameters to the image source URL, avoiding double CDNization in some cases, like if you have aliases configured.
Lazy Load: If enabled, only images close to the current viewpoint will be loaded.
Ignore SVG Size: If enabled, the module will ignore the image size node in the SVG file.
Prevent Image Resize: If you set Maximum "Pixel ratio" equal to 2, but some of your assets does not have min retina size(at least 2560x960), please enable this to prevent image resized. By default, yes.
Image Quality: The smaller the value, the more your image will be compressed. Careful — the quality of the image will decrease as well. By default, 90.
Maximum Pixel Ratio: The maximum pixel ratio of the image. By default, 2.
Remove V7: If enabled, the module will remove the "/v7" part in URL format. Activate for token created after October 20th 2021.
Advanced User
Custom JS Function: The valid js function starting with { and finishing with }
Custom Library Options: Modifies the library URL and must begin with the symbol &. Please read document before use.
Please note: if you are using an earlier version of Prestashop (v1.6.x or less) and / or this plugins is not compatible with some of your add-ons, it is always possible to make a manual integration of the Cloudimage acceleration, following the Prestashop tutorial.
Requires the installation and configuration of the plugin or .
To turn on responsive images,this option makes use of . All img tags "src" is changed to "ci-src" .
Shopify integration - frequently asked questions
Can I disable Cloudimage with a single click?
Yes you can enable and disable Cloudimage on your Shopify store with a single click. Navigate to Online store > Themes > Customize theme. In the sidebar, under general settings open Cloudimage.io and enable/disable it.
Can Cloudimage automatically detect the right image dimension and load it?
No Cloudimage only changes the base URL of your images because there is no way the server would have knowledge of your website layout. However, just by loading images through Cloudimage URL-endpoint, your images are automatically optimised for format and quality.
How do I make sure my integration is working?
Once you are done editing these files, save these files. Now refresh the webpage for your Shopify store and check the image URLs. They should now load from URLs beginning with https://{token}.cloudimg.io/v7
. You can use the Chrome Developer Tools to check that all the images are being loaded via Cloudimage.io and that all images are loading correctly. If you find that images on a particular page or section are still being served from Shopify, then find out the responsible theme file and edit it as well.
Cloudimage Sylius Plugin
The Cloudimage Sylius Plugin will automatically adapt the image URLs in your Sylius site to deliver your images rocket fast over the Cloudimage multi-CDN infrastructure. You only need to register with Cloudimage and install the plugin in your Sylius Admin.
To use the plugin, you need to have a Cloudimage account. You can create one on the Cloudimage registration page.
Open a command console on your Sylius hosting server, enter your project directory and execute the following command to download the latest stable version of this bundle:
Then, enable the plugin by adding it to the list of registered plugins/bundles in config/bundles.php file of your project
Update Channel Model Your Entity Channel has to implement \Scaleflex\SyliusCloudimagePlugin\Model\ExtendedChannelInterface
You can use Trait \Scaleflex\SyliusCloudimagePlugin\Model\ExtendedChannelTrait
Update Database Schema
Include
in your templates/bundles/SyliusAdminBundle\Channel_form.html.twig form.
Then you can start to personalize the configuration (token, options) in Admin / Channel -> Choose one Channel
To process your image through Cloudimage you have two ways to implement
Option 1: Use the ci_src(path)
Twig Function
Option 2: Define your own
Update the image src
to ci-src="{path}?q={sylius.channel.cloudimageImageQuality}"
Add the script
Here are the available configuration options:
Activation
Enable/Disable the plugin
Token
Token from Cloudimage (found in your admin panel)
Use origin URL
If enabled, the module will only add query parameters to the image source URL without prefixing it with {token}.cloudimg.io : might be useful to avoid double CDNization, for exemple if you have aliases configured
Ignore Image Size Node
Useful for improving compatibility with some themes.
Ignore Image Size Style
Useful for improving compatibility with some themes.
Lazy Loading
If enabled, images will be lazy-loaded for better initial loading times and user experience. ⚠️ lazy loading can have variable results on some websites as for the first rows of images loaded, therefore it is recommended to make use of an integrated new class provided: “lazy-off”. You can specify the "lazy-off" class either in the page builder through the back-office, or in the templates directly (eg. category page and product page).
Custom js function
🚨 Any js function to customize the behavior of the Cloudimage library. Attention, adding js should only be done by advanced administrators as it can break the js or have unintended effects if not thoroughly tested and validated.
Image Quality
Customizes image quality, therefore compression -influences the size of image-.applied by default. Warning, a setting under 80 might have a potentially visible impact.
Ignore SVG images
If enabled, all SVG images will be skipped from acceleration as anyway vector images will not be compressed.
Maximum "Pixel ratio"
List of supported device pixel ratios, default is 2, eg: 2 for Retina devices
Custom Library Options
When Javascript Mode is active, make sure that no other module is overwriting the plugin's delivery with "ci-src" image source.
Commercetools implementation
It is a simple and easy-to-use package that can help you improve the performance and user experience of your web application by optimizing it.
or
In this example, we're passing three props to the "CloudimageResponsive" component:
alt: The alternate text to display for the image. This is required for accessibility reasons.
image: The URL of the original image to be optimized and resized by Cloudimage.
cloudimageConfig: An object that contains the Cloudimage configuration parameters. This includes your Cloudimage API token, the base URL of your Cloudimage service, and the resizing, quality, and format parameters for the image.
Here are the configuration parameters you can use in the "cloudimageConfig" object:
token
Type: String | Default: "demo" | required
customDomain
Type: String | Default: "cloudimage.io" | optional
If you use a custom CNAME for your cloudimage integration, you can set it here.
baseURL
Type: String | Default: "/" | optional
Your image folder on server, this alows to shorten your origin image URLs.
apiVersion
Type: String |Default: 'v7' | optional
Allow to use a specific version of API.
set a specific version of API
disable API version
Note: this will disregard your token above as this should be built into the CNAME entry.
doNotReplaceURL
Type: bool | Default: false
If set to true the plugin will only add query params to the given source of image.
lazyLoading
Type: Bool | Default: true | optional
lazyLoadOffset
Type: Number/Array(Number) | Default: 100
Say if you want to preload a component even if it's 100px below the viewport (user have to scroll 100px more to see this component), you can set offset props to 100. On the other hand, if you want to delay loading a component even if it's top edge has already appeared at viewport, set offset to negative number.
Library supports horizontal lazy load out of the box. So when you provide this prop with number like 100 it will automatically set left edge offset to 100 and top edge to 100;
If you provide this prop with array like [100, 200], it will set left edge offset to 100 and top offset to 200.
params
Type: String | Default: 'org_if_sml=1' | optional
Applies default Cloudimage operations/ filters to your image, e.g. brightness, contrast, rotation... Multiple params can be applied, separated by "&" e.g. wat_scale=35&wat_gravity=northeast&wat_pad=10&grey=1
alternative syntax: type: Object
placeholderBackground
Type: String | Default: '#f4f4f4' | optional
Placeholder coloured background while the image is loading or use it to set your custom placeholder image or gif
For example:
lowQualityPreview
Type: Object
lowQualityPreview.minImgWidth number (default: 400) - minimum width of an image to load a low-quality preview image
presets
Type: Object
Default:
Breakpoints shortcuts to use in image size property, can be overridden.
limitFactor
Type: Number | Default: 100 | optional
Rounds up the size of an image to the nearest limitFactor value.
For example:
For an image with width 358px and limitFactor equal to 100, the plugin will round up to 400px.
For an image with width 358px and limitFactor equal to 5, the plugin will round up to 360px.
devicePixelRatioList
Type: [Number,...] | Default: [1, 1.5, 2] | optional
List of supported device pixel ratios. If there is no need to support retina devices, you should set an empty array devicePixelRatioList: [].
delay
Type: Number | optional
Delay for processing an image after rendering component.
NOTE: Normally, the parameter is not needed but in some cases with integrating third-party libraries, it can fix wrong calculation of image container.
ImageSizeAttributes
Type: String | possible values: 'use', 'ignore', 'take-ratio' | Default: 'use'
If width and height attributes are set:
use - width & height attributes values will be used to calculate image size (according to user's DPR) and ratio.
take-ratio - width & height attributes values will be used only to calculate ratio.
ignore - width & height attributes will be ignored.
If width and height attributes are NOT set, image container size will be detected to calculate result image size (according to user's DPR)
Note: If only width or height attributes is set, ratio is going to be taken from ci-ratio image attribute
Here are the properties you can use with the "CloudimageResponsive" component:
alt: The alternate text to display for the image. This is required for accessibility reasons.
image: The URL of the original image to be optimized and resized by Cloudimage.
cloudimageConfig: An object that contains the Cloudimage configuration parameters.
className: An optional class name to apply to the image container.
style: An optional object that contains CSS styles to apply to the image container.
Shopify integration - theme files
You need to adapt your individual theme files for the image URLs to be changed to Cloudimage URLs. Identify first which theme files are used by your shop and edit them one by one as detailled below.
Here are a couple of examples indicating the change that needs to be made in the theme files. You can follow similar steps to change all of your theme files. List of some files that need to be changed (files may vary between themes):
featured-product.liquid
product-template.liquid
collection-grid-item.liquid
Product-grid-item.liquid
header.liquid
video.liquid
As general what you need to do is:
assign new variable inheriting the original theme image url
replace the old image invocation with inclusion of cloudimage
You can make the changes inside product-template.liquid
.
Cloudimage Wordpress Plugin
You need to enter your Cloudimage account token which you have received upon account creation (step 1).
The v7 option
Some tokens are associated with a v7 URL, while others are not.
But not to worry, this plugin automatically checks and sets it for you, all within a few seconds.
Eg: If you enter a v7 token into the text input field, then a few seconds later, the v7 dial will automatically turn itself on.
Please be patient and wait for the “The v7 checking process …” message to disappear, before pressing the “SAVE ALL CHANGES“ button.
Your image URL will be like this:
Notice that the URLs has been appended with https://token.cloudimg.io/
to ensure CDN delivery and optimization of images.
With JS Mode turned on, Cloudimage will:
generate data-srcset
set resize
srcset
standard settingsNotice the 666 in the srcset
With this turned on, Cloudimage will only take effect when the user is logged in
Please note that Cloudimage will not take effect on localhosts
Disable image downsize filter
ON: disable WordPress’s default image-cropping functionality
Enable srcset
adding
If this is turned off, then “Srcset widths“ will have no effect.
srcset
widths (px)Add more sizes to srcset
For example
Cloudimage URL: token.cloudimg.io/mywebsite/wp-uploads/2020/image.png
Replaceable text: wp-uploads/2020
Replacement text: upload
Then from frontend users will see the image URL as: token.cloudimg.io/mywebsite/upload/image.png
(See above)
Exclude Cloudimage processing by class name
Exclude Cloudimage processing by file type, eg “.gif“
OFF: use ob_buffer
PHP function
ON: use the_content
filter from WordPress.
ON: use Cloudimage JS files from CDN
OFF: use Cloudimage JS files from plugin locally
Can become helpful to turn on when using non-standard WordPress themes. Especially for badly-made themes, to compensate for some adverse impact on images.
Enable Save Image Node Ratio to preserve the aspect ratio.
Turn on Ignore Image Node Size to bypass the incorrect width
and height
attributes.
Optionally, use Destroy Node Image Size if you want to completely remove size attributes from the image tags.
Use Detect Image Node CSS if the theme's CSS is involved in setting these incorrect sizes.
This setting ensures that only the width is considered for image processing, and the height is adjusted proportionally to maintain the aspect ratio.
setTimeout
checksBetter to turn this on when there are AJAX loaded images, so that the late-loaded images don’t miss out on Cloudimage processing
Shopify integration
Cloudimage will accelerate your Shopify shop by compressing images and delivering them over CDN.
After finding out your Shopify URL as shown below (i.e. https://cdn.shopify.com
, https://cdn2.shopify.com
or https://cdn.shopifycloud.com
), you can create a HTTP-Storage in Cloudimage.
Create the Storage record in the Cloudimage admin as follows:
Adding an HTTP-based Storage will make you create a Cloudimage Alias. After saving the storage in Step 1 above, verify that images are delivered correctly over your Cloudimage URL with the Alias:
Origin image URL on Shopify:
Cloudimage URL with Alias:
https://{token}.cloudimg.io/_myshopify_/shopifycloud/brochure/assets/home/hero-stock-small-72c1242fc5bbf6cfe135968110e9c52435af1e389c0fd4fe68208d21427e21e0.jpg
Replace {token}
with your Cloudimage token.
Proceed with making the changes in our Shopify settings and theme files to switch the image delivery to Cloudimage.
From your Shopify admin, click Online Store > Themes. Find the theme you want to edit, click the Actions button and then Edit code.
Under Config, click settings_schema.json
and append the code below after the last section of this file:
Create new files cloudimage.liquid
and cloudimage-video-tag.liquid
under the Snippets directory. Copy the code below into that file, and save it:
cloudimage.liquid
cloudimage-video-tag.liquid
Navigate to Online store > Themes > Customize theme. In the sidebar, under Theme Settings open Cloudimage and enable it. Fill out the below two fields:
Cloudimage Token - It should be your Cloudimage Token
Default URL endpoint - It should be //{token}.cloudimg.io/
myshopify
(where token
is your Cloudimage token)
Shopify CDN domain - Its value should be //cdn2.shopify.com
, //cdn.shopify.com
Hit the "Save" button.
The final step of this tutorial is to adapt your theme files to start delivering your images over Cloudimage.
Cloudimage caching and invalidation
Cloudimage leverages Content Delivery Networks to accelerate the delivery of your images worldwide. We work with multiple CDN providers to optimise the delivery of your images and provide superb reliability.
In addition to accelerating your images, the CDN provides DDoS (Distributed Denial of Service) protection, which will act as a shield to your servers and avoid any downtime.
CDNs usually cache images for as long as the images are requested by end users. If you want to update an original image, you have two ways of doing so in the CDN cache.
To refresh your images, you can either update the Cloudimage URL or invalidate them to flush them from the resizing servers and the CDN.
Old image:
//doc.cloudimg.io/sample.li/flat.jpg?w=500
New image:
//doc.cloudimg.io/sample.li/flat.jpg?w=500&vh=xx (whereas 'x' represent random numbers)
The vh=xx
will force the CDN to handle sample.li/flat.jpg?w=500&vh=xx as a new image version and update it's cache.
If you cannot change the image URLs when changing the origin image, you can still invalidate (flush) the image from the Cloudimage admin console. Log in to the console and navigate to Invalidation:
Do not use the full path of your image but only the /origin_image_url?operation&filter part as invalidation path. For example, to invalidate //doc.cloudimg.io/sample.li/flat1.jpg?w=500, you need to input /sample.li/flat1.jpg?w=500.
This will remove the image(s) from all CDN nodes and Cloudimage resizing servers.
The invalidation field assumes you are listing v7 Cloudimage paths. If you want to invalidate v6 Cloudimage URLs, you need to check the Use v6 API option
.
Token and image caching
CDN caching accelerates the loading times of images as it allows to host them as close as possible to your end users. By using CDN caching, your ensure maximum performance of your website. You can define the max-age
and s-maxage
attributes in the Cache-Control HTTP Header of images delivered by Cloudimage to control the caching behavior.
When this cache expired, the image will be requested from the origin and the new image delivered to the client. Reduce the default values if you have rotating images but static image URLs without versioning.
If you have rotating origin images but do not change the name, you need to follow the chart:
You can set the desired values in the admin console, under Image Settings -> Caching.
You can define the caching interval of a specific image by setting the ci_cache=X URL parameter of the image where X is the interval in seconds.
This will override the max-age
and s-maxage
attributes only for this image.
If you need to use a very small caching interval for a specific image (for example, snapshots from a live webcam or a specific chart with dynamically changing contents), you need to change the Automatic origin image refresh setting in your Admin console. This tells our resizing servers to update all origin images after this interval has expired.
The Ruby wrapper allows you to seamlessly interface with the Cloudimage API.
Add this line to your application's Gemfile:
And then execute:
Or install it yourself as:
The only requirement to get started is your customer token. You can find it within your Admin interface.
In order to interact with Cloudimage, we'll first initialize a client service object:
The Cloudimage client accepts the following options:
The calling path on the client object returns an instance of Cloudimage::URI. It accepts the path to the image as a string and we we will use it to build Cloudimage URLs.
Here are some common approaches for constructing Cloudimage URLs using this gem:
Hash of params
Pass a hash to to_url
. Every key becomes a param in the final Cloudimage URL so this gives you the freedom to pass arbitrary params if need be.
Chainable helpers
Every param supported by Cloudimage can be used as a helper method.
While every key passed into the to_url
method gets appended to the URL, chainable helper methods will throw a NoMethodError
when using an unsupported method.
This is useful for catching typos and identifying deprecated methods in case Cloudimage's API changes.
Method aliases
The gem comes with a handful of useful aliases. Consult the Cloudimage::Params module for their full list.
From the example above you can see that parameters that only serve as a flag don't need to accept arguments and will be translated into param=1
within the final URL.
Cloudimage Shopware module
Step 2: Zip the file with the name "cloudimage.zip"
Step 3: In Admin go to Extensions -> My extensions -> Upload extension
Step 1: In Admin go to Extensions -> Store -> Catalog and search for "Cloudimage by Scaleflex"
Step 2: Click on extension and after that "Add extension"
Step 3: Go to Extensions -> My extensions -> Cloudimage by Scaleflex -> Click on Configuration
Step 4: Update configuration and activate the Module, then your site is ready to go.
Activation: Enable/Disable the module
Standard Mode: Replace image URLs not using any Javascript or Javascript library.
Token or CNAME: Please enter your cloudimage token here (eg: abcdefgh), or your complete CNAME (eg. media.company.com) if the configuration is already validated in your Cloudimage Admin.
Use origin URL: If enabled, the module will only add query parameters to the image source URL without prefixing it with {token}.cloudimg.io
.
Lazy Load: If enabled, only images close to the current viewpoint will be loaded.
Ignore SVG Size: If enabled, the module will ignore the image size node in the SVG file.
Prevent Image Upsize: If you set Maximum "Pixel ratio" equal to 2, but some of your assets does not have min retina size(at least 2560x960), please enable this to prevent image resized. By default, yes.
Image Quality: The smaller the value, the more your image will be compressed. Careful — the quality of the image will decrease as well. By default, 90.
Maximum Pixel Ratio: The maximum pixel ratio of the image. By default, 2.
Remove V7: If enabled, the module will remove the "/v7" part in URL format. Activate for token created after October 20th 2021.
Advanced User's options
Custom JS Function: The valid js function starting with { and finishing with }
Custom Library Options: Modifies the library URL (to add transformations)
🚨 Those optional parameters will be added to the request for each URL going through the Cloudimage acceleration infrastructure. It can allow you to force image formats, apply automatic transformations or watermarking, and might be used for troubleshooting purposes. For advanced users only, please refer to the Cloudimage documentation for the list of possible parameters.
The library is a React component that allows you to easily add responsive images to your web application using the Cloudimage service. With this package, you can load and display optimized images that are automatically resized based on the device screen size and pixel density.
You can create an account on the .
You can install using npm or yarn:
To use , you need to provide it with a Cloudimage URL and some additional parameters. Here's an example:
Your Cloudimage customer token. for a Cloudimage account to get one. The subscription takes less than a minute and is totally free.
Only images close to the client's viewport will be loaded, hence accelerating the page loading time. The plugin uses library to achieve it.
If there is a tag inside image URL and you cannot simply assign it, use
You can also take a look at the section.
The will automatically adapt the image URLs in your Wordpress site to deliver your images rocket fast over Cloudimage. You only need to register with Cloudimage and install the plugin in your Wordpress site.
If you need to adjust the behaviour of the plugin, please see the settings.
Create an account if you have not registered already. You can create an account on the .
the ci-src
() attribute will be added into theimg
element, which will
lazy loading
But we need to configure in Cloudimage admin and set up the alias upload
with value wp-uploads/2020
Unable to delivery images over your Cloudimage URL? Contact if you are not able to fetch the image as explained above. In such a situation, do not move to step 3 as this could break your website images.
For more information, please see the and sections.
Alternatively, the allows to invalidate images via API.
We recommend using if you need to refresh your images as it will not impact your CDN cache-hit ratio.
For the full set of parameters and detailed implementation instructions, please consult the .
To use the plugin, you need to have a Cloudimage account. You can create one on the .
Step 1: Download the latest version
max-age
The time in seconds that the image is allowed to be re-used.
For instance, max-age=36000
indicates that an image remains in the browser cache for the next 36 000 seconds (10 hours).
s-maxage
This directive applies only to the caching in CDN. To maximise performance, we recommend you set a high value here and perform Invalidation on images when needed.
token
string
Required if cname
is missing.
cname
string
Required if token
is missing. See CNAME.
salt
string
Optional. See Security. Needed if you are using URL sealing or URL signatures.
signature_length
integer
Optional. Integer value in the range 6..40
. Defaults to 18.
sign_urls
boolean
Optional. Defaults to true. See Security.
aliases
hash
Optional. See URL aliases.
Process and cache your images before the first request with the Warmup API by Cloudimage
The Warmup API allows you to proactively cache your images in the Cloudimage infrastructure for faster processing before receiving the first request from your end users. We recommend to warm-up Cloudimage in the following cases:
upon launching a new collection of thousands/millions of images - to make sure that at launch time, all images will be pre-processed and rocket fast for end users;
at upload - to make sure that the uploaded image is already pre-processed to be immediately accessible for end users;
when dealing with large images (large animated GIF files, gigapixels pictures, etc.) - as pre-processing is important to save time on first load;
performance is a top priority even if it’s on the first load.
You can provide a list of your images either in a txt/csv file or in the request's body.
POSThttps://warmup.api.cloudimage.com/warmup/urls
You need to provide a text file with all your images for the warm-up (one URL per line):
X-Client-Key
is the client's API key (can be found in Admin Console left menu : Settings / CDN Invalidation).
X-Client-Key
is the client's API key (can be found in Admin Console left menu : Settings / CDN Invalidation).
You can check the status of the warm-up tasks for the last 5 days.
Supported with Ruby 2.4+, JRuby, and TruffleRuby github
Create invalidation requests via API
The Invalidation API is a REST API to invalidate images from the CDN and Cloudimage resizing servers.
Your API key is available in the Cloudimage admin console, under Invalidation:
Body:
The body of the request must contain the invalidation url in the form /_alias_/path/image1.jpg or /origin_image_url/image2.jpg.
Sample URL: https://doc.cloudimg.io/sample.li/boat.jpg?width=300
To invalidate all the resizes of this image, use: /sample.li/boat.jpg or v7/sample.li/boat.jpg.
Flushing all images will result in Cloudimage downloading all your images from your origin image storage again. This will result in slower image loading times for the first times the images are downloaded. Contact us if you have more than 1 TB of monthly CDN traffic or 1 TB of storage.
Try it out with the doc token doc
You can use our sample image showing the time it is resized the first time:
Migrating from another Image CDN
If your are transferring your image optimisation and CDN service from another provider, Cloudimage provides an easy way to migrate your images without code changes.
By migrating to Cloudimage, your images will need to be downloaded from their origin and cached by Cloudimage. Make sure your origin is able to process the initial load or contact us to perform a warm-up.
If your image is currently delivered via:
Then you need to replace the FQDN from yourdomain.provider.com
to token.cloudimg.io/
for the <img src>
to become:
If your image is currently available at http://token.provider/operations/sample.li/flat.jpg and referenced in your code as:
Then you need to adapt it to be:
Where:
token: your Cloudimage token you obtain after registering for a Cloudimage account
operations: the resizing operation(s) as listed under Image operations
filters: the filter transformation(s) as listed under Image filters
If your image is currently delivered via:
If your image is currently delivered via:
In both scenarios, migrating to Cloudimage only requires the change of your CNAME record for img.domain.com on your DNS provider.
Where:
token: your Cloudimage token you obtain after registering for a Cloudimage account
operations: the resizing operation(s) as listed under Image operations
filters: the filter transformation(s) as listed under Image filters
Cloudimage supports multiple image transformations format, contact us to discuss your migration project.