Resize, crop, and other common video transformations
A comprehensive guide that covers all the commonly used video transformations that you will need for your web applications.
Used to specify the width of the output video. Accepts integer value greater than 1.
When you specify just width, the height is adjusted accordingly to maintain the aspect ratio.
Original (1280x720)
Width 300px

Notice that height is automatically adjusted to maintain the aspect ratio.

Used to specify the height of the output video. Accepts integer value greater than 1.
When you specify only height, the width is adjusted accordingly to maintain the aspect ratio.
Original
Height 300px
Notice that width is automatically adjusted to maintain the aspect ratio.

Usage =
ar-<width>-<height>
If you specify both height(h) and width(w) in the URL along with aspect ratio(ar), then the aspect ratio is ignored.
Original
width 400px and aspect ratio 4:1
Tip for choosing the right cropping strategy
****When choosing among different strategies for cropping, think in terms of your website layout and desired output video dimension.
- If you want to preserve the whole video content without any cropping and need the exact same dimensions (height and width) in the output as requested, choose either the pad resize crop or forced crop strategy.
- If you want to preserve the whole video content without any cropping, but it is okay if one or both the dimensions (height or width) in the output are adjusted to preserve the aspect ratio. Then choose either the max-size cropping or min-size cropping strategy.
- If you need the exact same dimensions (height and width) in the output video as requested but it's okay to crop the video to preserve the aspect ratio. Then choose either the maintain ratio crop or the extract crop strategy. You can combine the extract crop strategy with different focus values to get the desired result.
In the pad resize crop strategy, the output dimension (height and width) is the same as requested, no cropping takes place, and the aspect ratio is preserved. This is accomplished by adding padding around the video to get it to match the exact dimension as requested.
In the examples above, we saw that when the video is padded using the pad resize crop strategy, the padding is equal on both sides of the video. However, there might be cases where we want all the padding to be added on only one side of the video. This can be done using the focus (fo) parameter.
Default crop (400x200)
cm-pad_resize (center focus)
cm-pad_resize with blurred background
cm-pad_resize (left)
https://ik.imagekit.io/demo/sample-video.mp4?tr=w-400,h-200
The video is 400x200 but it is cropped from all sides to preserve the aspect ratio.

https://ik.imagekit.io/demo/sample-video.mp4?tr=w-400,h-200,cm-pad_resize,bg-F3F3F3
The video is exactly 400x200 and there is no cropping. Extra padding with background color F3F3F3 has been added to get 400x200 output dimensions.

https://ik.imagekit.io/demo/sample2.mp4?tr=w-400,h-200,cm-pad_resize,bg-blurred
The video is exactly 700x700 and there is no cropping. The extra padding added consists of a blurred background made using the source video to get 400x200 output dimensions.

You can also control the focus point using fo parameter to move the actual content to one side using relative positioning.
We added the
fo-left
. Now, all the padding is on the right of the video.
In a forced crop strategy, the output video's dimension (height and width) is exactly the same as requested, no cropping takes place, but the aspect ratio is not preserved. It forcefully squeezes the original video to get it to fit completely within the output dimensions.
URL - https://ik.imagekit.io/demo/sample-video.mp4?tr=w-200,h-200,c-force
Notice that the aspect ratio is changed and the video looks squeezed.

In the max-size crop strategy, whole video content is preserved without any cropping, the aspect ratio is preserved, but one of the dimensions (height or width) is adjusted.
The output video is less than or equal to the dimensions specified in the URL,i.e., at least one dimension will exactly match the output dimension requested, and the other dimension will be equal to or smaller than the corresponding output dimension requested.
Notice that the aspect ratio is maintained and there is no cropping. But the height is reduced so that the video fits within a 200x200 container.

This strategy is similar to the max-size cropping strategy, with the only difference being that, unlike the max-size strategy, the output video dimension is equal to or larger than the requested dimensions. One of the dimensions will be exactly the same as what is requested, while the other dimension will be equal to or larger than what is requested.
Notice that the height is 200px as requested, but the width is more than 200px. The aspect ratio is maintained and there is no cropping.\

This is the default crop strategy. If nothing is specified in the URL, this strategy gets applied automatically. In this strategy, the output video's dimension (height and width) is the same as requested, and the aspect ratio is preserved. This is accomplished by resizing the video to the requested dimension and then cropping extra parts to get desired height & width.
By default, ImageKit.io crops the video from the center but you can change this using the focus parameter.
URL - https://ik.imagekit.io/demo/sample-video.mp4?tr=w-400,h-200
Notice that the video's dimension matches 400x200 but the content is cropped from all edges i.e by default ImageKit will extract the video from the center. You can change this behaviour using the focus parameter.

In this strategy, the output video's dimension (height and width) is exactly the same as requested, and the aspect ratio is preserved. In this strategy, instead of trying to resize the video as we did in maintain ratio strategy, we extract out a region of the requested dimension from the original video.
By default, ImageKit.io extracts the video from the center but you can change this using the focus parameter.
Default center extract
Relative focus
A 300x200 part is extracted from the center of the original video.

In the relative method, you can use the focus (fo) parameter to specify that the extract should be done from, let's say, the bottom of the original video.
Valid relative values for
fo
parameters are - center
, top
, left
, bottom
, right
, top_left
, top_right
, bottom_left
and bottom_right
.
This parameter can be used along with pad resize, maintain ratio or extract crop to change the behaviour of padding or cropping. Learn more from the different examples shown in respective sections.
This parameter can have the following values depending upon where it is being used:
- 1.
left
,right
,top
,bottom
can be to control the position of padding when used with pad resize. Learn from example. - 2.
center
,top
,left
,bottom
,right
,top_left
,top_right
,bottom_left
andbottom_right
can be used to define relative cropping during extract crop. Learn from examples.
ImageKit.io allows you to choose a quality level between
1
and 100
. 1
results in the lowest perceptual quality and smallest file size. 100
results in the highest perceptual quality and biggest file size.Choosing 100 quality will not improve an already low-quality video. However, it will increase the size of the video file. It is recommended to not use a 100 quality setting.
Default Value -
50
. You can be change automatic video quality optimization setting from the dashboard.Video size is 3.3MB which is larger than the original 1.1MB video.

Video at quality 90
Video size is 406KB which is less than half of the original 1.1MB video. File size is reduced by 60% and there is no perceptual change in the output video.

Video at quality 50
Used to specify the format of the output video. If no output format is specified then based on your settings in the dashboard, ImageKit.io automatically picks the best format for that video request.
Possible values include
auto
,mp4
, webm
.Default Value -
auto
. You can disable automatic video format conversion from the dashboard settings.Used to specify the audio codec for encoding the output.
Possible values include
aac
, opus
, and none
.Use
none
for removing audio from the source video. So the output will have no audio.Used to specify the video codec for encoding the output.
Possible values include
h264
, vp9
, av1
and none
Use
none
for extracting audio from the source video. So the output will be an audio file.f | ac | vc |
---|---|---|
mp4 | aac | h264 |
mp4 | aac | none |
mp4 | none | h264 |
webm | opus | vp9 |
webm | opus | none |
webm | none | vp9 |
webm | opus | av1 |
webm | none | av1 |