Window width:
Breakpoint:

Examples

Image Examples

Responsive image with srcset & sizes

Display a responsive image in a normal container column layout.

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-md-6 col-lg-4 col-xl-3">
      <?= ResponsivePics::get_image(1, 'xs-12, md-6, lg-4, xl-3'); ?>
    </div>
  </div>
</div>

This method will output a <img> element that spans 12 columns from the xs breakpoint and up, 6 columns from the md breakpoint, 4 columns from the lg breakpoint and up and 3 columns from the xl breakpoint and up.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<img srcset="/app/uploads/2020/10/samuel-zeller-168223-240x360.jpg 240w, /app/uploads/2020/10/samuel-zeller-168223-240x360@2x.jpg 480w, /app/uploads/2020/10/samuel-zeller-168223-290x435.jpg 290w, /app/uploads/2020/10/samuel-zeller-168223-290x435@2x.jpg 580w, /app/uploads/2020/10/samuel-zeller-168223-330x495.jpg 330w, /app/uploads/2020/10/samuel-zeller-168223-330x495@2x.jpg 660w, /app/uploads/2020/10/samuel-zeller-168223-510x765.jpg 510w, /app/uploads/2020/10/samuel-zeller-168223-510x765@2x.jpg 1020w, /app/uploads/2020/10/samuel-zeller-168223-546x819.jpg 546w, /app/uploads/2020/10/samuel-zeller-168223-546x819@2x.jpg 1092w" sizes="(min-width: 1200px) 240px, (min-width: 992px) 290px, (min-width: 768px) 330px, (min-width: 576px) 510px, (min-width: 0px) 546px, 100vw" alt="Responsive image"/>
Data
Array
(
    [alpha] => 
    [alt] => Responsive image
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2020/10/samuel-zeller-168223-240x360.jpg
                    [source2x] => /app/uploads/2020/10/samuel-zeller-168223-240x360@2x.jpg
                    [width] => 240
                    [height] => 360
                    [ratio] => 0.66666666666667
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2020/10/samuel-zeller-168223-290x435.jpg
                    [source2x] => /app/uploads/2020/10/samuel-zeller-168223-290x435@2x.jpg
                    [width] => 290
                    [height] => 435
                    [ratio] => 0.66666666666667
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2020/10/samuel-zeller-168223-330x495.jpg
                    [source2x] => /app/uploads/2020/10/samuel-zeller-168223-330x495@2x.jpg
                    [width] => 330
                    [height] => 495
                    [ratio] => 0.66666666666667
                )

            [3] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2020/10/samuel-zeller-168223-510x765.jpg
                    [source2x] => /app/uploads/2020/10/samuel-zeller-168223-510x765@2x.jpg
                    [width] => 510
                    [height] => 765
                    [ratio] => 0.66666666666667
                )

            [4] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2020/10/samuel-zeller-168223-546x819.jpg
                    [source2x] => /app/uploads/2020/10/samuel-zeller-168223-546x819@2x.jpg
                    [width] => 546
                    [height] => 819
                    [ratio] => 0.66666666666667
                )

        )

    [lazyload] => 
    [classes] => Array
        (
        )

)
Rendered
Responsive image

Cropped responsive image with srcset & sizes

Display a responsive image in a normal container column layout with a cropped height from the left bottom of 75% of the width.

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-md-6 col-lg-12">
      <?= ResponsivePics::get_image(1, 'xs-12, md-6, lg:400', 0,75|l b); ?>
    </div>
  </div>
</div>

This method will output a <img> element that spans 12 columns from the xs breakpoint and up, 6 columns from the md breakpoint and up and 400px from the lg breakpoint and up.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<img srcset="/app/uploads/2020/09/alex-shutin-204369-unsplash-400x300-crop-0-100.jpg 400w, /app/uploads/2020/09/alex-shutin-204369-unsplash-400x300-crop-0-100@2x.jpg 800w, /app/uploads/2020/09/alex-shutin-204369-unsplash-330x248-crop-0-100.jpg 330w, /app/uploads/2020/09/alex-shutin-204369-unsplash-330x248-crop-0-100@2x.jpg 660w, /app/uploads/2020/09/alex-shutin-204369-unsplash-546x410-crop-0-100.jpg 546w, /app/uploads/2020/09/alex-shutin-204369-unsplash-546x410-crop-0-100@2x.jpg 1092w" sizes="(min-width: 992px) 400px, (min-width: 768px) 330px, (min-width: 0px) 546px, 100vw" alt="Image with srcset & sizes attacking example"/>
Data
Array
(
    [alpha] => 
    [alt] => Image with srcset & sizes attacking example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2020/09/alex-shutin-204369-unsplash-400x300-crop-0-100.jpg
                    [source2x] => /app/uploads/2020/09/alex-shutin-204369-unsplash-400x300-crop-0-100@2x.jpg
                    [width] => 400
                    [height] => 300
                    [ratio] => 1.3333333333333
                )

            [1] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2020/09/alex-shutin-204369-unsplash-330x248-crop-0-100.jpg
                    [source2x] => /app/uploads/2020/09/alex-shutin-204369-unsplash-330x248-crop-0-100@2x.jpg
                    [width] => 330
                    [height] => 248
                    [ratio] => 1.3306451612903
                )

            [2] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2020/09/alex-shutin-204369-unsplash-546x410-crop-0-100.jpg
                    [source2x] => /app/uploads/2020/09/alex-shutin-204369-unsplash-546x410-crop-0-100@2x.jpg
                    [width] => 546
                    [height] => 410
                    [ratio] => 1.3317073170732
                )

        )

    [lazyload] => 
    [classes] => Array
        (
        )

)
Rendered
Image with srcset & sizes attacking example

Image Focal Point Cropping

To crop an image from the focal point that has been set manually from the media library, use the f crop shorthand.

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-md-6 col-lg-4">
      <?= ResponsivePics::get_image(1, 'xs-12, md-6, lg-4', 2|f, true); ?>
    </div>
  </div>
</div>

This method will output a <img> element that spans 12 columns from the xs breakpoint and up, 6 columns from the md breakpoint and up and 4 columns from the lg breakpoint and up.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<img class="lazyload" data-srcset="/app/uploads/2020/10/chris-holgersson-236098-330x660-crop-16-48.jpg 330w, /app/uploads/2020/10/chris-holgersson-236098-330x660-crop-16-48@2x.jpg 660w, /app/uploads/2020/10/chris-holgersson-236098-290x580-crop-16-48.jpg 290w, /app/uploads/2020/10/chris-holgersson-236098-290x580-crop-16-48@2x.jpg 580w, /app/uploads/2020/10/chris-holgersson-236098-330x660-crop-16-48.jpg 330w, /app/uploads/2020/10/chris-holgersson-236098-330x660-crop-16-48@2x.jpg 660w, /app/uploads/2020/10/chris-holgersson-236098-510x1020-crop-16-48.jpg 510w, /app/uploads/2020/10/chris-holgersson-236098-510x1020-crop-16-48@2x.jpg 1020w, /app/uploads/2020/10/chris-holgersson-236098-546x1092-crop-16-48.jpg 546w, /app/uploads/2020/10/chris-holgersson-236098-546x1092-crop-16-48@2x.jpg 1092w" sizes="(min-width: 1200px) 330px, (min-width: 992px) 290px, (min-width: 768px) 330px, (min-width: 576px) 510px, (min-width: 0px) 546px, 100vw" alt="Responsive background image"/>
Data
Array
(
    [alpha] => 
    [alt] => Responsive background image
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2020/10/chris-holgersson-236098-330x660-crop-16-48.jpg
                    [source2x] => /app/uploads/2020/10/chris-holgersson-236098-330x660-crop-16-48@2x.jpg
                    [width] => 330
                    [height] => 660
                    [ratio] => 0.5
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2020/10/chris-holgersson-236098-290x580-crop-16-48.jpg
                    [source2x] => /app/uploads/2020/10/chris-holgersson-236098-290x580-crop-16-48@2x.jpg
                    [width] => 290
                    [height] => 580
                    [ratio] => 0.5
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2020/10/chris-holgersson-236098-330x660-crop-16-48.jpg
                    [source2x] => /app/uploads/2020/10/chris-holgersson-236098-330x660-crop-16-48@2x.jpg
                    [width] => 330
                    [height] => 660
                    [ratio] => 0.5
                )

            [3] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2020/10/chris-holgersson-236098-510x1020-crop-16-48.jpg
                    [source2x] => /app/uploads/2020/10/chris-holgersson-236098-510x1020-crop-16-48@2x.jpg
                    [width] => 510
                    [height] => 1020
                    [ratio] => 0.5
                )

            [4] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2020/10/chris-holgersson-236098-546x1092-crop-16-48.jpg
                    [source2x] => /app/uploads/2020/10/chris-holgersson-236098-546x1092-crop-16-48@2x.jpg
                    [width] => 546
                    [height] => 1092
                    [ratio] => 0.5
                )

        )

    [lazyload] => 1
    [classes] => Array
        (
            [0] => lazyload
        )

)
Rendered
Responsive background image

LQIP (low quality image placeholder)

To enable a LQIP (low quality image placeholder) for your responsive image, pass true as the 5th parameter:

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-md-6 col-lg-12">
      <?= ResponsivePics::get_image(1, 'xs-12, md-6, lg-4', false, true, true); ?>
    </div>
  </div>
</div>

Now your responsive image will show as a small (pixelated) placeholder image before the actual full (sharp) image is done loading.
Additionally you could even add a ‘fade-out blur’ effect when you also enabled lazyload for the image:

img {
	&.blur-up {
		width: 100%;
		height: auto;

		&.lazyload {
			opacity: 1;
			filter: blur(5px);
			transition: filter .75s ease;
		}

		&.lazyloaded {
			filter: blur(0);
		}
	}
}

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<img class="lazyload blur-up" data-srcset="/app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-330x495.jpg 330w, /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-330x495@2x.jpg 660w, /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-290x435.jpg 290w, /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-290x435@2x.jpg 580w, /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-330x495.jpg 330w, /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-330x495@2x.jpg 660w, /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-510x765.jpg 510w, /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-510x765@2x.jpg 1020w, /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-546x819.jpg 546w, /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-546x819@2x.jpg 1092w" sizes="(min-width: 1200px) 330px, (min-width: 992px) 290px, (min-width: 768px) 330px, (min-width: 576px) 510px, (min-width: 0px) 546px, 100vw" src="/app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-100x150.jpg" alt="LQIP example"/>
Data
Array
(
    [alpha] => 
    [alt] => LQIP example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-330x495.jpg
                    [source2x] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-330x495@2x.jpg
                    [width] => 330
                    [height] => 495
                    [ratio] => 0.66666666666667
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-290x435.jpg
                    [source2x] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-290x435@2x.jpg
                    [width] => 290
                    [height] => 435
                    [ratio] => 0.66666666666667
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-330x495.jpg
                    [source2x] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-330x495@2x.jpg
                    [width] => 330
                    [height] => 495
                    [ratio] => 0.66666666666667
                )

            [3] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-510x765.jpg
                    [source2x] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-510x765@2x.jpg
                    [width] => 510
                    [height] => 765
                    [ratio] => 0.66666666666667
                )

            [4] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-546x819.jpg
                    [source2x] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-546x819@2x.jpg
                    [width] => 546
                    [height] => 819
                    [ratio] => 0.66666666666667
                )

        )

    [lazyload] => 1
    [lqip] => /app/uploads/2021/03/george-kedenburg-iii-561935-unsplash-100x150.jpg
    [classes] => Array
        (
            [0] => lazyload
            [1] => blur-up
        )

)
Rendered
LQIP example

Picture Examples

Images in container grid columns

Display an responsive picture in a normal container column layout:

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-sm-6 col-md-4">
      <?= ResponsivePics::get_picture(1, 'xs-12, sm-6, md-4'); ?>
    </div>
  </div>
</div>

This method will output a <picture> element that spans 12 contained columns from the xs breakpoint and up, 6 contained columns from the sm breakpoint and up and 4 contained columns from the md breakpoint and up.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<picture>
  <source media="(min-width: 1200px)" srcset="/app/uploads/2019/06/martin-adams-740397-unsplash-330x220.jpg 1x, /app/uploads/2019/06/martin-adams-740397-unsplash-330x220@2x.jpg 2x" />
  <source media="(min-width: 992px)" srcset="/app/uploads/2019/06/martin-adams-740397-unsplash-290x193.jpg 1x, /app/uploads/2019/06/martin-adams-740397-unsplash-290x193@2x.jpg 2x" />
  <source media="(min-width: 768px)" srcset="/app/uploads/2019/06/martin-adams-740397-unsplash-210x140.jpg 1x, /app/uploads/2019/06/martin-adams-740397-unsplash-210x140@2x.jpg 2x" />
  <source media="(min-width: 576px)" srcset="/app/uploads/2019/06/martin-adams-740397-unsplash-240x160.jpg 1x, /app/uploads/2019/06/martin-adams-740397-unsplash-240x160@2x.jpg 2x" />
  <source media="(min-width: 0px)" srcset="/app/uploads/2019/06/martin-adams-740397-unsplash-546x364.jpg 1x, /app/uploads/2019/06/martin-adams-740397-unsplash-546x364@2x.jpg 2x" />
  <img src="" alt="Grid system columns example" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => Grid system columns example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2019/06/martin-adams-740397-unsplash-330x220.jpg
                    [source2x] => /app/uploads/2019/06/martin-adams-740397-unsplash-330x220@2x.jpg
                    [width] => 330
                    [height] => 220
                    [ratio] => 1.5
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2019/06/martin-adams-740397-unsplash-290x193.jpg
                    [source2x] => /app/uploads/2019/06/martin-adams-740397-unsplash-290x193@2x.jpg
                    [width] => 290
                    [height] => 193
                    [ratio] => 1.5025906735751
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2019/06/martin-adams-740397-unsplash-210x140.jpg
                    [source2x] => /app/uploads/2019/06/martin-adams-740397-unsplash-210x140@2x.jpg
                    [width] => 210
                    [height] => 140
                    [ratio] => 1.5
                )

            [3] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2019/06/martin-adams-740397-unsplash-240x160.jpg
                    [source2x] => /app/uploads/2019/06/martin-adams-740397-unsplash-240x160@2x.jpg
                    [width] => 240
                    [height] => 160
                    [ratio] => 1.5
                )

            [4] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2019/06/martin-adams-740397-unsplash-546x364.jpg
                    [source2x] => /app/uploads/2019/06/martin-adams-740397-unsplash-546x364@2x.jpg
                    [width] => 546
                    [height] => 364
                    [ratio] => 1.5
                )

        )

    [lazyload] => 
    [intrinsic] => 
    [picture_classes] => Array
        (
        )

    [image_classes] => Array
        (
        )

)
Rendered
Grid system columns example

Images in full-width grid columns

When your image is in a full-width fluid container, you can use the -full suffix:

<div class="container-fluid">
  <div class="row">
    <div class="col-xs-12 col-sm-6 col-md-4">
      <?= ResponsivePics::get_picture(1, 'xs-12-full, sm-6-full, md-4-full'); ?>
    </div>
  </div>
</div>

This method will output a <picture> element that spans 12 full-width columns from the xs breakpoint and up, 6 full-width columns from the sm breakpoint and up and 4 full-width columns from the md breakpoint and up.

Since the largest default breakpoint xxl is 1400px, the width of the image will never exceed the 12 full-width columns of 1400px (1370px) with this method. To prevent this, you need to add custom breakpoints higher then xxl.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<picture>
  <source media="(min-width: 1200px)" srcset="/app/uploads/2019/07/aziz-acharki-549137-unsplash-436x281.jpg 1x, /app/uploads/2019/07/aziz-acharki-549137-unsplash-436x281@2x.jpg 2x" />
  <source media="(min-width: 992px)" srcset="/app/uploads/2019/07/aziz-acharki-549137-unsplash-370x238.jpg 1x, /app/uploads/2019/07/aziz-acharki-549137-unsplash-370x238@2x.jpg 2x" />
  <source media="(min-width: 768px)" srcset="/app/uploads/2019/07/aziz-acharki-549137-unsplash-300x193.jpg 1x, /app/uploads/2019/07/aziz-acharki-549137-unsplash-300x193@2x.jpg 2x" />
  <source media="(min-width: 576px)" srcset="/app/uploads/2019/07/aziz-acharki-549137-unsplash-354x228.jpg 1x, /app/uploads/2019/07/aziz-acharki-549137-unsplash-354x228@2x.jpg 2x" />
  <source media="(min-width: 0px)" srcset="/app/uploads/2019/07/aziz-acharki-549137-unsplash-546x352.jpg 1x, /app/uploads/2019/07/aziz-acharki-549137-unsplash-546x352@2x.jpg 2x" />
  <img src="" alt="Full width image example" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => Full width image example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2019/07/aziz-acharki-549137-unsplash-436x281.jpg
                    [source2x] => /app/uploads/2019/07/aziz-acharki-549137-unsplash-436x281@2x.jpg
                    [width] => 436
                    [height] => 281
                    [ratio] => 1.5516014234875
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2019/07/aziz-acharki-549137-unsplash-370x238.jpg
                    [source2x] => /app/uploads/2019/07/aziz-acharki-549137-unsplash-370x238@2x.jpg
                    [width] => 370
                    [height] => 238
                    [ratio] => 1.5546218487395
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2019/07/aziz-acharki-549137-unsplash-300x193.jpg
                    [source2x] => /app/uploads/2019/07/aziz-acharki-549137-unsplash-300x193@2x.jpg
                    [width] => 300
                    [height] => 193
                    [ratio] => 1.5544041450777
                )

            [3] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2019/07/aziz-acharki-549137-unsplash-354x228.jpg
                    [source2x] => /app/uploads/2019/07/aziz-acharki-549137-unsplash-354x228@2x.jpg
                    [width] => 354
                    [height] => 228
                    [ratio] => 1.5526315789474
                )

            [4] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2019/07/aziz-acharki-549137-unsplash-546x352.jpg
                    [source2x] => /app/uploads/2019/07/aziz-acharki-549137-unsplash-546x352@2x.jpg
                    [width] => 546
                    [height] => 352
                    [ratio] => 1.5511363636364
                )

        )

    [lazyload] => 
    [intrinsic] => 
    [picture_classes] => Array
        (
        )

    [image_classes] => Array
        (
        )

)
Rendered
Full width image example

Full-width images

When your image is not in a container and you want to display your image full-width, you can use the full shorthand:

<div>
  <?= ResponsivePics::get_picture(1, 'xs-full'); ?>
</div>

This method will output a <picture> element that spans the full-width defined by the next breakpoint width from the xs breakpoint and up.

Since the largest default breakpoint xxl is 1400px, the width of the image will never exceed the 1400px with this method. To prevent this, you need to add custom breakpoints higher then xxl.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<picture>
  <source media="(min-width: 1200px)" srcset="/app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-1400x1051.jpg 1x, /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-1400x1051@2x.jpg 2x" />
  <source media="(min-width: 992px)" srcset="/app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-1200x901.jpg 1x, /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-1200x901@2x.jpg 2x" />
  <source media="(min-width: 768px)" srcset="/app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-992x745.jpg 1x, /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-992x745@2x.jpg 2x" />
  <source media="(min-width: 576px)" srcset="/app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-768x577.jpg 1x, /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-768x577@2x.jpg 2x" />
  <source media="(min-width: 0px)" srcset="/app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-576x432.jpg 1x, /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-576x432@2x.jpg 2x" />
  <img src="" alt="Full-width image example" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => Full-width image example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-1400x1051.jpg
                    [source2x] => /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-1400x1051@2x.jpg
                    [width] => 1400
                    [height] => 1051
                    [ratio] => 1.3320647002854
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-1200x901.jpg
                    [source2x] => /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-1200x901@2x.jpg
                    [width] => 1200
                    [height] => 901
                    [ratio] => 1.3318534961154
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-992x745.jpg
                    [source2x] => /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-992x745@2x.jpg
                    [width] => 992
                    [height] => 745
                    [ratio] => 1.3315436241611
                )

            [3] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-768x577.jpg
                    [source2x] => /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-768x577@2x.jpg
                    [width] => 768
                    [height] => 577
                    [ratio] => 1.3310225303293
                )

            [4] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-576x432.jpg
                    [source2x] => /app/uploads/2020/11/willian-justen-de-vasconcellos-515780-unsplash-576x432@2x.jpg
                    [width] => 576
                    [height] => 432
                    [ratio] => 1.3333333333333
                )

        )

    [lazyload] => 
    [intrinsic] => 
    [picture_classes] => Array
        (
        )

    [image_classes] => Array
        (
        )

)
Rendered
Full-width image example

Custom image widths

When your image is not in a normal container or column layout, you can also use custom image widths:

<?= ResponsivePics::get_picture(1, 'xs:500, sm:725, md:950'); ?>

This method will output a <picture> element of 500px from the xs breakpoint and up, 725px from the sm breakpoint and up and 950px from the md breakpoint and up.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<picture>
  <source media="(min-width: 768px)" srcset="/app/uploads/2019/06/hyunwon-jang-741306-unsplash-950x633.jpg 1x, /app/uploads/2019/06/hyunwon-jang-741306-unsplash-950x633@2x.jpg 2x" />
  <source media="(min-width: 576px)" srcset="/app/uploads/2019/06/hyunwon-jang-741306-unsplash-725x483.jpg 1x, /app/uploads/2019/06/hyunwon-jang-741306-unsplash-725x483@2x.jpg 2x" />
  <source media="(min-width: 0px)" srcset="/app/uploads/2019/06/hyunwon-jang-741306-unsplash-500x333.jpg 1x, /app/uploads/2019/06/hyunwon-jang-741306-unsplash-500x333@2x.jpg 2x" />
  <img src="" alt="Custom image sizes example" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => Custom image sizes example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2019/06/hyunwon-jang-741306-unsplash-950x633.jpg
                    [source2x] => /app/uploads/2019/06/hyunwon-jang-741306-unsplash-950x633@2x.jpg
                    [width] => 950
                    [height] => 633
                    [ratio] => 1.5007898894155
                )

            [1] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2019/06/hyunwon-jang-741306-unsplash-725x483.jpg
                    [source2x] => /app/uploads/2019/06/hyunwon-jang-741306-unsplash-725x483@2x.jpg
                    [width] => 725
                    [height] => 483
                    [ratio] => 1.5010351966874
                )

            [2] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2019/06/hyunwon-jang-741306-unsplash-500x333.jpg
                    [source2x] => /app/uploads/2019/06/hyunwon-jang-741306-unsplash-500x333@2x.jpg
                    [width] => 500
                    [height] => 333
                    [ratio] => 1.5015015015015
                )

        )

    [lazyload] => 
    [intrinsic] => 
    [picture_classes] => Array
        (
        )

    [image_classes] => Array
        (
        )

)
Rendered
Custom image sizes example

Mixed image widths

You can also mix container column image widths with custom image widths:

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-md-6 col-lg-12">
      <?= ResponsivePics::get_picture(1, 'xs-12, md-6, lg:800, xl:1024'); ?>
    </div>
  </div>
</div>

This method will output a <picture> element that spans 12 columns from the xs breakpoint and up, 6 columns from the md breakpoint and up, 800px from the lg breakpoint and up and 1000px from the xl breakpoint and up.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<picture>
  <source media="(min-width: 1200px)" srcset="/app/uploads/2019/06/kyler-nixon-208875-unsplash-1024x682.jpg 1x, /app/uploads/2019/06/kyler-nixon-208875-unsplash-1024x682@2x.jpg 2x" />
  <source media="(min-width: 992px)" srcset="/app/uploads/2019/06/kyler-nixon-208875-unsplash-800x533.jpg 1x, /app/uploads/2019/06/kyler-nixon-208875-unsplash-800x533@2x.jpg 2x" />
  <source media="(min-width: 768px)" srcset="/app/uploads/2019/06/kyler-nixon-208875-unsplash-330x220.jpg 1x, /app/uploads/2019/06/kyler-nixon-208875-unsplash-330x220@2x.jpg 2x" />
  <source media="(min-width: 0px)" srcset="/app/uploads/2019/06/kyler-nixon-208875-unsplash-546x364.jpg 1x, /app/uploads/2019/06/kyler-nixon-208875-unsplash-546x364@2x.jpg 2x" />
  <img src="" alt="Combined image sizes example" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => Combined image sizes example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2019/06/kyler-nixon-208875-unsplash-1024x682.jpg
                    [source2x] => /app/uploads/2019/06/kyler-nixon-208875-unsplash-1024x682@2x.jpg
                    [width] => 1024
                    [height] => 682
                    [ratio] => 1.5014662756598
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2019/06/kyler-nixon-208875-unsplash-800x533.jpg
                    [source2x] => /app/uploads/2019/06/kyler-nixon-208875-unsplash-800x533@2x.jpg
                    [width] => 800
                    [height] => 533
                    [ratio] => 1.5009380863039
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2019/06/kyler-nixon-208875-unsplash-330x220.jpg
                    [source2x] => /app/uploads/2019/06/kyler-nixon-208875-unsplash-330x220@2x.jpg
                    [width] => 330
                    [height] => 220
                    [ratio] => 1.5
                )

            [3] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2019/06/kyler-nixon-208875-unsplash-546x364.jpg
                    [source2x] => /app/uploads/2019/06/kyler-nixon-208875-unsplash-546x364@2x.jpg
                    [width] => 546
                    [height] => 364
                    [ratio] => 1.5
                )

        )

    [lazyload] => 
    [intrinsic] => 
    [picture_classes] => Array
        (
        )

    [image_classes] => Array
        (
        )

)
Rendered
Combined image sizes example

Custom breakpoints

When your picture needs to change size on a non-default breakpoint, you can also use custom breakpoints:

<?= ResponsivePics::get_picture(1, '400:200, 800:400'); ?>

This method will output a <picture> element that spans 200px from 400px breakpoint and up and 400px from 800px breakpoint and up.

Since we didn’t define any image size before breakpoint 400px, the image won’t be resized from breakpoint 0px to 400px which will be bad for performance.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<picture>
  <source media="(min-width: 800px)" srcset="/app/uploads/2019/06/denys-nevozhai-189623-unsplash-400x284.jpg 1x, /app/uploads/2019/06/denys-nevozhai-189623-unsplash-400x284@2x.jpg 2x" />
  <source media="(min-width: 400px)" srcset="/app/uploads/2019/06/denys-nevozhai-189623-unsplash-200x142.jpg 1x, /app/uploads/2019/06/denys-nevozhai-189623-unsplash-200x142@2x.jpg 2x" />
  <source media="(min-width: 0px)" srcset="/app/uploads/2019/06/denys-nevozhai-189623-unsplash.jpg" />
  <img src="" alt="Custom breakpoints example" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => Custom breakpoints example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 800
                    [source1x] => /app/uploads/2019/06/denys-nevozhai-189623-unsplash-400x284.jpg
                    [source2x] => /app/uploads/2019/06/denys-nevozhai-189623-unsplash-400x284@2x.jpg
                    [width] => 400
                    [height] => 284
                    [ratio] => 1.4084507042254
                )

            [1] => Array
                (
                    [breakpoint] => 400
                    [source1x] => /app/uploads/2019/06/denys-nevozhai-189623-unsplash-200x142.jpg
                    [source2x] => /app/uploads/2019/06/denys-nevozhai-189623-unsplash-200x142@2x.jpg
                    [width] => 200
                    [height] => 142
                    [ratio] => 1.4084507042254
                )

            [2] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2019/06/denys-nevozhai-189623-unsplash.jpg
                    [width] => 4450
                    [height] => 3167
                    [ratio] => 1.4051152510262
                )

        )

    [lazyload] => 
    [intrinsic] => 
    [picture_classes] => Array
        (
        )

    [image_classes] => Array
        (
        )

)
Rendered
Custom breakpoints example

Custom image heights

When you want to limit the height of your picture without cropping it, you can set the (maximum) image height:

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-md-8 col-lg-12">
      <?= ResponsivePics::get_picture(1, 'xs-12 800, md-8 500, lg:400 400, xl:600/0.75'); ?>
    </div>
  </div>
</div>

This method will output a <picture> element that spans 12 columns and a max height of 800px from the xs breakpoint and up, 8 columns and a max height of 500px from the md breakpoint and up, 400px and a max height of 400px from the lg breakpoint and up and 600px and a max height of 600px * 0.75 (= 450px) from the xl breakpoint and up.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<picture>
  <source media="(min-width: 1200px)" srcset="/app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-600x450.jpg 1x, /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-600x450@2x.jpg 2x" />
  <source media="(min-width: 992px)" srcset="/app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-400x400.jpg 1x, /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-400x400@2x.jpg 2x" />
  <source media="(min-width: 768px)" srcset="/app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-450x500.jpg 1x, /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-450x500@2x.jpg 2x" />
  <source media="(min-width: 0px)" srcset="/app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-546x800.jpg 1x, /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-546x800@2x.jpg 2x" />
  <img src="" alt="Custom image heights example" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => Custom image heights example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-600x450.jpg
                    [source2x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-600x450@2x.jpg
                    [width] => 600
                    [height] => 450
                    [ratio] => 1.3333333333333
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-400x400.jpg
                    [source2x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-400x400@2x.jpg
                    [width] => 400
                    [height] => 400
                    [ratio] => 1
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-450x500.jpg
                    [source2x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-450x500@2x.jpg
                    [width] => 450
                    [height] => 500
                    [ratio] => 0.9
                )

            [3] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-546x800.jpg
                    [source2x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-546x800@2x.jpg
                    [width] => 546
                    [height] => 800
                    [ratio] => 0.6825
                )

        )

    [lazyload] => 
    [intrinsic] => 
    [picture_classes] => Array
        (
        )

    [image_classes] => Array
        (
        )

)
Rendered
Custom image heights example

Image cropping

When you want full control over your picture dimensions, you can enable cropping:

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-md-8 col-lg-12">
      <?= ResponsivePics::get_picture(1, 'xs-12 800|c, md-8 500|c, lg:400 400|l t, xl:500/0.75|r b'); ?>
    </div>
  </div>
</div>

This method will output a <picture> element that spans 12 columns and with a height of 800px cropped from the center from the xs breakpoint and up, 8 columns and a height of 500px cropped from the center from the md breakpoint and up, 400px and a height of 400px cropped from the left top from the lg breakpoint and up and 600px and a height of 600px * 0.75 (= 450px) cropped from the right bottom from the xl breakpoint and up.

When setting a height and a crop, ResponsivePics will try to resize and crop the image to the desired width and height only if the original image dimensions allow it. If not, it will resize and crop to the largest possible size while keeping the desired crop ratio.

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<picture>
  <source media="(min-width: 1200px)" srcset="/app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-500x375-crop-100-100.jpg 1x, /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-500x375-crop-100-100@2x.jpg 2x" />
  <source media="(min-width: 992px)" srcset="/app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-400x400-crop-0-0.jpg 1x, /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-400x400-crop-0-0@2x.jpg 2x" />
  <source media="(min-width: 768px)" srcset="/app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-450x500-center-center.jpg 1x, /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-450x500-center-center@2x.jpg 2x" />
  <source media="(min-width: 0px)" srcset="/app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-546x800-center-center.jpg 1x, /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-546x800-center-center@2x.jpg 2x" />
  <img src="" alt="Custom image heights example" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => Custom image heights example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-500x375-crop-100-100.jpg
                    [source2x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-500x375-crop-100-100@2x.jpg
                    [width] => 500
                    [height] => 375
                    [ratio] => 1.3333333333333
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-400x400-crop-0-0.jpg
                    [source2x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-400x400-crop-0-0@2x.jpg
                    [width] => 400
                    [height] => 400
                    [ratio] => 1
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-450x500-center-center.jpg
                    [source2x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-450x500-center-center@2x.jpg
                    [width] => 450
                    [height] => 500
                    [ratio] => 0.9
                )

            [3] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-546x800-center-center.jpg
                    [source2x] => /app/uploads/2019/06/h-e-n-g-s-t-r-e-a-m-744456-unsplash-546x800-center-center@2x.jpg
                    [width] => 546
                    [height] => 800
                    [ratio] => 0.6825
                )

        )

    [lazyload] => 
    [intrinsic] => 
    [picture_classes] => Array
        (
        )

    [image_classes] => Array
        (
        )

)
Rendered
Custom image heights example

Image cropping from focal point

When you want to make sure that a certain part of your image is always visible while cropping, you can use the f crop shorthand.
You can manually set the crop point in the WordPress media library:

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-md-6 col-lg-4">
      <?= ResponsivePics::get_picture(1, 'xs-12/0.5|f, md-6/1|f, lg-4/2|f', null, true); ?>
    </div>
  </div>
</div>

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<picture>
  <source media="(min-width: 1200px)" data-srcset="/app/uploads/2022/01/linus-nylund-437333-unsplash-330x660-crop-64-40.jpg 1x, /app/uploads/2022/01/linus-nylund-437333-unsplash-330x660-crop-64-40@2x.jpg 2x" />
  <source media="(min-width: 992px)" data-srcset="/app/uploads/2022/01/linus-nylund-437333-unsplash-290x580-crop-64-40.jpg 1x, /app/uploads/2022/01/linus-nylund-437333-unsplash-290x580-crop-64-40@2x.jpg 2x" />
  <source media="(min-width: 768px)" data-srcset="/app/uploads/2022/01/linus-nylund-437333-unsplash-330x330-crop-64-40.jpg 1x, /app/uploads/2022/01/linus-nylund-437333-unsplash-330x330-crop-64-40@2x.jpg 2x" />
  <source media="(min-width: 576px)" data-srcset="/app/uploads/2022/01/linus-nylund-437333-unsplash-510x255-crop-64-40.jpg 1x, /app/uploads/2022/01/linus-nylund-437333-unsplash-510x255-crop-64-40@2x.jpg 2x" />
  <source media="(min-width: 0px)" data-srcset="/app/uploads/2022/01/linus-nylund-437333-unsplash-546x273-crop-64-40.jpg 1x, /app/uploads/2022/01/linus-nylund-437333-unsplash-546x273-crop-64-40@2x.jpg 2x" />
  <img src="" alt="" class="lazyload" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => 
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2022/01/linus-nylund-437333-unsplash-330x660-crop-64-40.jpg
                    [source2x] => /app/uploads/2022/01/linus-nylund-437333-unsplash-330x660-crop-64-40@2x.jpg
                    [width] => 330
                    [height] => 660
                    [ratio] => 0.5
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2022/01/linus-nylund-437333-unsplash-290x580-crop-64-40.jpg
                    [source2x] => /app/uploads/2022/01/linus-nylund-437333-unsplash-290x580-crop-64-40@2x.jpg
                    [width] => 290
                    [height] => 580
                    [ratio] => 0.5
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2022/01/linus-nylund-437333-unsplash-330x330-crop-64-40.jpg
                    [source2x] => /app/uploads/2022/01/linus-nylund-437333-unsplash-330x330-crop-64-40@2x.jpg
                    [width] => 330
                    [height] => 330
                    [ratio] => 1
                )

            [3] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2022/01/linus-nylund-437333-unsplash-510x255-crop-64-40.jpg
                    [source2x] => /app/uploads/2022/01/linus-nylund-437333-unsplash-510x255-crop-64-40@2x.jpg
                    [width] => 510
                    [height] => 255
                    [ratio] => 2
                )

            [4] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2022/01/linus-nylund-437333-unsplash-546x273-crop-64-40.jpg
                    [source2x] => /app/uploads/2022/01/linus-nylund-437333-unsplash-546x273-crop-64-40@2x.jpg
                    [width] => 546
                    [height] => 273
                    [ratio] => 2
                )

        )

    [lazyload] => 1
    [intrinsic] => 
    [picture_classes] => Array
        (
        )

    [image_classes] => Array
        (
            [0] => lazyload
        )

)
Rendered

Lazyloading

To enable lazy loading for your responsive picture, pass true as the 4th parameter:

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-lg-10 col-xl-8">
      <?= ResponsivePics::get_picture(1, 'xs-12, lg-10, xl-8', 'lazyload-effect', true); ?>
    </div>
  </div>
</div>

Now your responsive image will only load when it’s in the viewport and thus will increase performance on your website!

Additionally you could even add a fade-in css effect once the image is lazyloaded:

picture.lazyload-effect {
	img {
		&.lazyload,
		&.lazyloading {
			opacity: 0;
			transition: opacity .75s ease;
		}

		&.lazyloaded {
			opacity: 1;
		}
	}
}

Depending on the maximum size of the uploaded image with ID 1, the output with special lazyload markup will be something like:

HTML
<picture class="lazyload-effect">
  <source media="(min-width: 1200px)" data-srcset="/app/uploads/2019/06/joshua-coleman-654602-unsplash-690x460.jpg 1x, /app/uploads/2019/06/joshua-coleman-654602-unsplash-690x460@2x.jpg 2x" />
  <source media="(min-width: 992px)" data-srcset="/app/uploads/2019/06/joshua-coleman-654602-unsplash-770x513.jpg 1x, /app/uploads/2019/06/joshua-coleman-654602-unsplash-770x513@2x.jpg 2x" />
  <source media="(min-width: 768px)" data-srcset="/app/uploads/2019/06/joshua-coleman-654602-unsplash-690x460.jpg 1x, /app/uploads/2019/06/joshua-coleman-654602-unsplash-690x460@2x.jpg 2x" />
  <source media="(min-width: 576px)" data-srcset="/app/uploads/2019/06/joshua-coleman-654602-unsplash-510x340.jpg 1x, /app/uploads/2019/06/joshua-coleman-654602-unsplash-510x340@2x.jpg 2x" />
  <source media="(min-width: 0px)" data-srcset="/app/uploads/2019/06/joshua-coleman-654602-unsplash-546x364.jpg 1x, /app/uploads/2019/06/joshua-coleman-654602-unsplash-546x364@2x.jpg 2x" />
  <img src="" alt="Lazyloading example" class="lazyload" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => Lazyloading example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2019/06/joshua-coleman-654602-unsplash-690x460.jpg
                    [source2x] => /app/uploads/2019/06/joshua-coleman-654602-unsplash-690x460@2x.jpg
                    [width] => 690
                    [height] => 460
                    [ratio] => 1.5
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2019/06/joshua-coleman-654602-unsplash-770x513.jpg
                    [source2x] => /app/uploads/2019/06/joshua-coleman-654602-unsplash-770x513@2x.jpg
                    [width] => 770
                    [height] => 513
                    [ratio] => 1.5009746588694
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2019/06/joshua-coleman-654602-unsplash-690x460.jpg
                    [source2x] => /app/uploads/2019/06/joshua-coleman-654602-unsplash-690x460@2x.jpg
                    [width] => 690
                    [height] => 460
                    [ratio] => 1.5
                )

            [3] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2019/06/joshua-coleman-654602-unsplash-510x340.jpg
                    [source2x] => /app/uploads/2019/06/joshua-coleman-654602-unsplash-510x340@2x.jpg
                    [width] => 510
                    [height] => 340
                    [ratio] => 1.5
                )

            [4] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2019/06/joshua-coleman-654602-unsplash-546x364.jpg
                    [source2x] => /app/uploads/2019/06/joshua-coleman-654602-unsplash-546x364@2x.jpg
                    [width] => 546
                    [height] => 364
                    [ratio] => 1.5
                )

        )

    [lazyload] => 1
    [intrinsic] => 
    [picture_classes] => Array
        (
            [0] => lazyload-effect
        )

    [image_classes] => Array
        (
            [0] => lazyload
        )

)
Rendered
Lazyloading example

Intrinsic Aspectratio

To enable intrinsic aspect ratio for your responsive picture, pass true as the 5th parameter:

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-lg-10 col-xl-8">
      <?= ResponsivePics::get_picture(1, 'xs-12, lg-10, xl-8', '', true, true); ?>
    </div>
  </div>
</div>

When you installed the Lazysizes aspectratio extension, it will try to calculate each picture’s image element’s height based upon each data-aspectratio attribute and set the height as an inline style. This way the image already takes up space in your layout.

Additionally you could even add some placeholder styling when the image is not loaded yet, but does have a height already:

picture.intrinsic {
	position: relative;
	display: block;
	margin: 0;
	width: 100%;
	background: #e4e4e4 url('../images/icon.svg') no-repeat center;
	background-size: 50px 50px;

	&__item {
		display: block;
		width: 100%;
	}
}

Depending on the maximum size of the uploaded image with ID 1, the output with special intrinsic markup will be something like:

HTML
<picture class="intrinsic">
  <source media="(min-width: 1200px)" data-srcset="/app/uploads/2019/06/lionel-gustave-171878-unsplash-690x1035.jpg 1x, /app/uploads/2019/06/lionel-gustave-171878-unsplash-690x1035@2x.jpg 2x" data-aspectratio="0.66666666666667" />
  <source media="(min-width: 992px)" data-srcset="/app/uploads/2019/06/lionel-gustave-171878-unsplash-770x1155.jpg 1x, /app/uploads/2019/06/lionel-gustave-171878-unsplash-770x1155@2x.jpg 2x" data-aspectratio="0.66666666666667" />
  <source media="(min-width: 768px)" data-srcset="/app/uploads/2019/06/lionel-gustave-171878-unsplash-690x1035.jpg 1x, /app/uploads/2019/06/lionel-gustave-171878-unsplash-690x1035@2x.jpg 2x" data-aspectratio="0.66666666666667" />
  <source media="(min-width: 576px)" data-srcset="/app/uploads/2019/06/lionel-gustave-171878-unsplash-510x765.jpg 1x, /app/uploads/2019/06/lionel-gustave-171878-unsplash-510x765@2x.jpg 2x" data-aspectratio="0.66666666666667" />
  <source media="(min-width: 0px)" data-srcset="/app/uploads/2019/06/lionel-gustave-171878-unsplash-546x819.jpg 1x, /app/uploads/2019/06/lionel-gustave-171878-unsplash-546x819@2x.jpg 2x" data-aspectratio="0.66666666666667" />
  <img src="" data-aspectratio="" alt="Intrinsic example" class="lazyload intrinsic__item" style="width:100%;" />
</picture>
Data
Array
(
    [alpha] => 
    [alt] => Intrinsic example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2019/06/lionel-gustave-171878-unsplash-690x1035.jpg
                    [source2x] => /app/uploads/2019/06/lionel-gustave-171878-unsplash-690x1035@2x.jpg
                    [width] => 690
                    [height] => 1035
                    [ratio] => 0.66666666666667
                )

            [1] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2019/06/lionel-gustave-171878-unsplash-770x1155.jpg
                    [source2x] => /app/uploads/2019/06/lionel-gustave-171878-unsplash-770x1155@2x.jpg
                    [width] => 770
                    [height] => 1155
                    [ratio] => 0.66666666666667
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2019/06/lionel-gustave-171878-unsplash-690x1035.jpg
                    [source2x] => /app/uploads/2019/06/lionel-gustave-171878-unsplash-690x1035@2x.jpg
                    [width] => 690
                    [height] => 1035
                    [ratio] => 0.66666666666667
                )

            [3] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2019/06/lionel-gustave-171878-unsplash-510x765.jpg
                    [source2x] => /app/uploads/2019/06/lionel-gustave-171878-unsplash-510x765@2x.jpg
                    [width] => 510
                    [height] => 765
                    [ratio] => 0.66666666666667
                )

            [4] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2019/06/lionel-gustave-171878-unsplash-546x819.jpg
                    [source2x] => /app/uploads/2019/06/lionel-gustave-171878-unsplash-546x819@2x.jpg
                    [width] => 546
                    [height] => 819
                    [ratio] => 0.66666666666667
                )

        )

    [lazyload] => 1
    [intrinsic] => 1
    [picture_classes] => Array
        (
            [0] => intrinsic
        )

    [image_classes] => Array
        (
            [0] => lazyload
            [1] => intrinsic__item
        )

)
Rendered
Intrinsic example

Background Examples

Responsive background image

When you want to create a responsive background image, you can use the get_background function.
For displaying a responsive background image in a normal container column layout:

<div class="container">
  <div class="row">
    <div class="col-xs-12 col-md-8 col-lg-4 col-xl-6">
      <?= ResponsivePics::get_background(1, 'xs-12, md-8, lg-4, xl-6', 'responsive-bg-example'); ?>
    </div>
  </div>
</div>

Don’t forget to style your background image otherwise you won’t see anything. You can do this by passing a css class as the 3rd parameter:

.responsive-bg-example {
	display: block;
	width: 100%;
	overflow: hidden;
	height: 0;
	padding-top: 75%;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<style scoped="scoped" type="text/css">
  @media (min-width: 0px) {
  #responsive-pics-background-708 {background-image: url("/app/uploads/2020/10/chris-holgersson-236098-546x364.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 0px), only screen and (min-resolution: 192dpi) and (min-width: 0px) {
  #responsive-pics-background-708 {background-image: url("/app/uploads/2020/10/chris-holgersson-236098-546x364@2x.jpg");}
  }
  @media (min-width: 576px) {
  #responsive-pics-background-708 {background-image: url("/app/uploads/2020/10/chris-holgersson-236098-510x340.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 576px), only screen and (min-resolution: 192dpi) and (min-width: 576px) {
  #responsive-pics-background-708 {background-image: url("/app/uploads/2020/10/chris-holgersson-236098-510x340@2x.jpg");}
  }
  @media (min-width: 768px) {
  #responsive-pics-background-708 {background-image: url("/app/uploads/2020/10/chris-holgersson-236098-450x300.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 768px), only screen and (min-resolution: 192dpi) and (min-width: 768px) {
  #responsive-pics-background-708 {background-image: url("/app/uploads/2020/10/chris-holgersson-236098-450x300@2x.jpg");}
  }
  @media (min-width: 992px) {
  #responsive-pics-background-708 {background-image: url("/app/uploads/2020/10/chris-holgersson-236098-290x193.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 992px), only screen and (min-resolution: 192dpi) and (min-width: 992px) {
  #responsive-pics-background-708 {background-image: url("/app/uploads/2020/10/chris-holgersson-236098-290x193@2x.jpg");}
  }
  @media (min-width: 1200px) {
  #responsive-pics-background-708 {background-image: url("/app/uploads/2020/10/chris-holgersson-236098-510x340.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 1200px), only screen and (min-resolution: 192dpi) and (min-width: 1200px) {
  #responsive-pics-background-708 {background-image: url("/app/uploads/2020/10/chris-holgersson-236098-510x340@2x.jpg");}
  }
  }
</style>
<div id="responsive-pics-background-708" class="responsive-bg-example"></div>
Data
Array
(
    [alpha] => 
    [alt] => Responsive background image
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2020/10/chris-holgersson-236098-546x364.jpg
                    [source2x] => /app/uploads/2020/10/chris-holgersson-236098-546x364@2x.jpg
                    [width] => 546
                    [height] => 364
                    [ratio] => 1.5
                )

            [1] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2020/10/chris-holgersson-236098-510x340.jpg
                    [source2x] => /app/uploads/2020/10/chris-holgersson-236098-510x340@2x.jpg
                    [width] => 510
                    [height] => 340
                    [ratio] => 1.5
                )

            [2] => Array
                (
                    [breakpoint] => 768
                    [source1x] => /app/uploads/2020/10/chris-holgersson-236098-450x300.jpg
                    [source2x] => /app/uploads/2020/10/chris-holgersson-236098-450x300@2x.jpg
                    [width] => 450
                    [height] => 300
                    [ratio] => 1.5
                )

            [3] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2020/10/chris-holgersson-236098-290x193.jpg
                    [source2x] => /app/uploads/2020/10/chris-holgersson-236098-290x193@2x.jpg
                    [width] => 290
                    [height] => 193
                    [ratio] => 1.5025906735751
                )

            [4] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2020/10/chris-holgersson-236098-510x340.jpg
                    [source2x] => /app/uploads/2020/10/chris-holgersson-236098-510x340@2x.jpg
                    [width] => 510
                    [height] => 340
                    [ratio] => 1.5
                )

        )

    [id] => responsive-pics-background-708-1
    [classes] => Array
        (
            [0] => responsive-bg-example
        )

)
Rendered

Full-width responsive background banner

In this example, we will be creating a full-width banner background image with a responsive aspect ratio:

<?= ResponsivePics::get_background(1, 'xs-full/0.65|c, sm-full/0.5|c, md-full|c, lg-full/0.5|c, xl:1500/0.35|c, 1500:1750/0.35|c, 1750:2000/0.3|c, 2000:2500/0.25|c', 'my-hero-bg-example'); ?>

When you pass a class as the 3rd parameter, you can style the div that contains the background image:

.my-hero-bg-example {
	display: block;
	width: 100%;
	height: 65vw;
	background-image: url('');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	transition: background-image .75s ease;

	@include media-breakpoint-up(sm) {
		height: 50vw;
	}

	@include media-breakpoint-up(lg) {
		height: 40vw;
	}

	@include media-breakpoint-up(xl) {
		height: 35vw;
	}

	@media (min-width: 1600px) {
		height: 30vw;
	}

	@media (min-width: 2000px) {
		height: 25vw;
	}
}

Depending on the maximum size of the uploaded image with ID 1, the output will be something like:

HTML
<style scoped="scoped" type="text/css">
  @media (min-width: 0px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-576x374-center-center.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 0px), only screen and (min-resolution: 192dpi) and (min-width: 0px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-576x374-center-center@2x.jpg");}
  }
  @media (min-width: 576px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-768x384-center-center.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 576px), only screen and (min-resolution: 192dpi) and (min-width: 576px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-768x384-center-center@2x.jpg");}
  }
  @media (min-width: 992px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-1200x480-center-center.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 992px), only screen and (min-resolution: 192dpi) and (min-width: 992px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-1200x480-center-center@2x.jpg");}
  }
  @media (min-width: 1200px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-1500x525-center-center.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 1200px), only screen and (min-resolution: 192dpi) and (min-width: 1200px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-1500x525-center-center@2x.jpg");}
  }
  @media (min-width: 1500px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-1750x612-center-center.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 1500px), only screen and (min-resolution: 192dpi) and (min-width: 1500px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-1750x612-center-center@2x.jpg");}
  }
  @media (min-width: 1750px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-2000x600-center-center.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 1750px), only screen and (min-resolution: 192dpi) and (min-width: 1750px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-2000x600-center-center@2x.jpg");}
  }
  @media (min-width: 2000px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-2500x625-center-center.jpg");}
  }
  @media only screen and (-webkit-min-device-pixel-ratio: 2) and (min-width: 2000px), only screen and (min-resolution: 192dpi) and (min-width: 2000px) {
  #responsive-pics-background-581 {background-image: url("/app/uploads/2019/07/fuyong-hua-274676-unsplash-2500x625-center-center@2x.jpg");}
  }
  }
</style>
<div id="responsive-pics-background-581" class="my-hero-bg-example"></div>
Data
Array
(
    [alpha] => 
    [alt] => Background image example
    [animated] => 
    [mimetype] => image/jpeg
    [sources] => Array
        (
            [0] => Array
                (
                    [breakpoint] => 0
                    [source1x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-576x374-center-center.jpg
                    [source2x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-576x374-center-center@2x.jpg
                    [width] => 576
                    [height] => 374
                    [ratio] => 1.5401069518717
                )

            [1] => Array
                (
                    [breakpoint] => 576
                    [source1x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-768x384-center-center.jpg
                    [source2x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-768x384-center-center@2x.jpg
                    [width] => 768
                    [height] => 384
                    [ratio] => 2
                )

            [2] => Array
                (
                    [breakpoint] => 992
                    [source1x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-1200x480-center-center.jpg
                    [source2x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-1200x480-center-center@2x.jpg
                    [width] => 1200
                    [height] => 480
                    [ratio] => 2.5
                )

            [3] => Array
                (
                    [breakpoint] => 1200
                    [source1x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-1500x525-center-center.jpg
                    [source2x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-1500x525-center-center@2x.jpg
                    [width] => 1500
                    [height] => 525
                    [ratio] => 2.8571428571429
                )

            [4] => Array
                (
                    [breakpoint] => 1500
                    [source1x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-1750x612-center-center.jpg
                    [source2x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-1750x612-center-center@2x.jpg
                    [width] => 1750
                    [height] => 612
                    [ratio] => 2.859477124183
                )

            [5] => Array
                (
                    [breakpoint] => 1750
                    [source1x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-2000x600-center-center.jpg
                    [source2x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-2000x600-center-center@2x.jpg
                    [width] => 2000
                    [height] => 600
                    [ratio] => 3.3333333333333
                )

            [6] => Array
                (
                    [breakpoint] => 2000
                    [source1x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-2500x625-center-center.jpg
                    [source2x] => /app/uploads/2019/07/fuyong-hua-274676-unsplash-2500x625-center-center@2x.jpg
                    [width] => 2500
                    [height] => 625
                    [ratio] => 4
                )

        )

    [id] => responsive-pics-background-581-1
    [classes] => Array
        (
            [0] => my-hero-bg-example
        )

)
Rendered