One of the most useful functions to both theme and plugin developers, when it comes to working with images, is add_image_size(), which allows you to create additional automatically generated image sizes to the WordPress image upload process.

The function is great developers, but one of the things it does not do is provide a simple way for the end user to select the image size when inserting an image into the editor via the media upload window. With a simple filter however, we can easily enable additional radio buttons for any custom image size we want, as shown in the image below:

All we need to do is setup a function that takes an array as a parameter. Inside of the function, we will add our custom image sizes by adding new array keys for each image size we want to make available. Each array key is set to the label we want to show next to the radio button. Once we have modified the array, all we need to do is return it and connect the function to the image_size_names_choose filter:

function pw_add_image_sizes() {
    add_image_size( 'pw-thumb', 300, 100, true );
    add_image_size( 'pw-large', 600, 300, true );
add_action( 'init', 'pw_add_image_sizes' );
function pw_show_image_sizes($sizes) {
    $sizes['pw-thumb'] = __( 'Custom Thumb', 'pippin' );
    $sizes['pw-large'] = __( 'Custom Large', 'pippin' );
    return $sizes;
add_filter('image_size_names_choose', 'pw_show_image_sizes');
  1. Jordan

    Simple, concise, helpful, and highly useful -thanks.

  2. Brad Dalton

    Yeah great little tut that helps everyone using WordPress.

  3. SlotsMarvel

    very helpful, thanks for this.
    Any chance that you know how to set the dimensions dynamically using a variable?

    Something like this

    add_image_size( ‘mythumb’, $custom_width, $custom_height, true );

    above doesn’t want to work, only if I enter the exact pixels values width numbers.

    • Pippin

      Where are your variables getting set from?

    • SlotsMarvel

      I am using this in a plugin that creates a widget. The values of the variables are set via the widget settings and are declared further up in the same php file.
      Basically I want to let the users set the thumbnail size via widget options panel.

    • Pippin

      It is possible but it will only apply to images that are uploaded after the size is created.

  4. 0161-Jon

    Hi Pippin,

    do you know how to get this working for twentytwelve? Is it possible or is it just using the image editor within the theme now?

    I just prefer the easy selector of the pre defined image types as per your tutorial but can’t get them working in twentytwelve. And I know that is the easier option for clients too.



  5. Dave Yankowiak

    Just used this on a client project. Thanks for the tutorial, Pippin!

  6. Matt

    Anyone else able to get this working with 3.6.1? No luck here…

    • Pippin

      Do the image sizes not show up?

    • Matt

      Hi Pippen. No, they’re not. Well, not in the Add Media > Attachment Display Settings anyway (Alignment, Link to, Size). Only the default sizes (thumbnail, medium, full) are available in the dropdown menu.

    • Pippin

      Did you put the code in a theme or plugin? Can you confirm it is active?

    • Matt

      Theme, (functions file), confirmed…

      Is it working correctly for you in 3.6.1?

    • Pippin

      I’ve just tested and they are showing fine in the main media upload window from the post edit screen.

    • Matt

      Hi Pippin,

      Just noted your reply to another post above, that the sizes only apply to images uploaded after the size is created. After slapping myself in the forehead and punching myself in the ribs (for added measure) I’ve noted it is indeed working. (Regenerating the thumbnails in my media library took care of the images uploaded prior to.)

      Thanks Pippin! Great function. Sorry for the gaff!

  7. Matt

    p.s. I’ve since spread the love with a tweet. Thanks again!

  8. syed

    product/add product/add media /insert from url /after that placeholder insert image how can i fix that please

  9. Latz

    It’s not necessary to use the “init” hook. The code needs only to be loaded if you’re on the admin post page, so an “admin_init” will be enough.

  10. Anton

    You need to merge the Array
    return array_merge( $sizes, array( ‘big’ => ‘Big’ ) );

Your email address will not be published. Required fields are marked *

Error: Please enter a valid email address

Error: Invalid email

Error: Please enter your first name

Error: Please enter your last name

Error: Please enter a username

Error: Please enter a password

Error: Please confirm your password

Error: Password and password confirmation do not match