[wp-trac] [WordPress Trac] #18951: A function to add default images for themes

WordPress Trac wp-trac at lists.automattic.com
Fri Oct 14 17:19:27 UTC 2011


#18951: A function to add default images for themes
-----------------------------+-----------------------------
 Reporter:  F J Kaiser       |      Owner:
     Type:  feature request  |     Status:  new
 Priority:  normal           |  Milestone:  Awaiting Review
Component:  Themes           |    Version:  3.2.1
 Severity:  normal           |   Keywords:
-----------------------------+-----------------------------
 Adding default images to themes is not an easy task. They have to play
 nicely with different image sizes that are built-in and/or added via
 {{{add_image_size();}}}. If they don't, then they will simply break the
 layout or won't change with user changes. Sadly we can't simply use most
 of the core media/image functions as those functions check if the image is
 an attachment image and - if not - abort.

 So I want to introduce {{{wp_default_img();}}}. It works with an input
 array of attributes and offers two filters (wp_default_img_attr &
 wp_default_img). So setting up default images is as easy as using a filter
 (if the theme developer isn't satisfied with the functions default args)
 and finally just adding

 {{{
 // functions.php during init:
 add_image_size( 'default_img', 80, 80, true );

 // Inside some template
 $placeholder = get_site_url( null, 'your_path' ).'/some_img.jpg';
 echo wp_default_img( array( 'url' => $placeholder, 'size' => 'default_img'
 ) );
 }}}

 The function also cares about cropping images if 4th argument set to
 {{{true}}} when registering the size using {{{add_image_size();}}}.

 The actual function (documented as far as possible).

 {{{
 /**
  * Default image
  *
  * Builds an default <img> for use in themes or plugins before any other
 images are added.
  * Resizes & crops the image using the built-in (retireved via
 `get_intermediate_image_sizes();`)
  * or custom image (added via `add_image_size();`) sizes.
  *
  * Retrieves calculated resize dimension @uses image_resize_dimensions();
  * Builds the width and height string @uses image_hwstring();
  *
  * @param $args (array)
  *              string $url URl to the given default image.
  *              string $size Optional. Default is 'medium'.
  *              string (optional) $alt Image Description for the alt
 attribute.
  *              string (optional) $title Image Description for the title
 attribute.
  *              string (optional) $align Part of the class name for
 aligning the image.
  *              string (optional) $echo Wheter to return or echo the
 $image
  * @return string HTML IMG element for given image attachment
  */
 function wp_default_img( $attr = array( 'url', 'size' => 'medium',
 'classes' => false, 'alt' => false, 'title' => false, 'align' => 'none',
 'echo' => true ) )
 {
         // Sizes registered via add_image_size();
         global $_wp_additional_image_sizes;

         if ( 'thumb' === $attr['size'] )
                 $attr['size'] = 'thumbnail';

         // Size in built in sizes - call size setting from DB
         # behavoir in here dependent on @link
 http://core.trac.wordpress.org/ticket/18947
         if ( ! in_array( $attr['size'], array_keys(
 $_wp_additional_image_sizes ) ) )
         {
                 $sizes                          =
 get_intermediate_image_sizes();
                 // Get option - gladly autoloaded/can use wp_cache_get();
                 $size_data['width']     = intval( get_option(
 "{$attr['size']}_size_w") );
                 $size_data['height']= intval( get_option(
 "{$attr['size']}_size_h") );
                 // Not sure how this will behave if cropped is false
 (autoloaded option not added)
                 $size_data['crop']      = get_option(
 "{$attr['size']}_crop" ) ? get_option( "{$attr['size']}_crop" ) : false;
         }
         // Size array from global registered additional/custom sizes array
         else
         {
                 $size_data = $_wp_additional_image_sizes[ $attr['size'] ];
         }

         // Retrieve image width & height
         $img_info       = @getimagesize( $attr['url'] );

         // Calculate final dimensions - if "crop" was set to true during
 add_image_size(), the img will get ... cropped
         $end_sizes      = image_resize_dimensions( $img_info[0],
 $img_info[1], $size_data['width'], $size_data['height'],
 $size_data['crop'] );

         // defaults to px units - can't get changed, as applying units is
 not possible
         $hwstring       = ' '.trim( image_hwstring( $end_sizes[4],
 $end_sizes[5] ) );

         // Attributes:
         // Not made required as users tend to do funky things (...and lock
 screen readers out)
         $attr['alt'] = $attr['alt'] ? ' alt="'.esc_attr( $attr['alt']
 )."'" : '';

         if ( ! $attr['title'] )
                 $attr['title'] = sprintf( __('default image of type:
 %1$s'), explode( "/", $img_info['mime'] ) );
         $attr['title'] = $attr['title'] ? ' title="'.esc_attr(
 $attr['title'] )."'" : '';

         $attr['classes'] = "wp-img-default ".esc_attr( $attr['classes'] ?
 $attr['classes'] : '' );
         $attr['align'] = $attr['align'] ? "align".esc_attr( $attr['align']
 ) : '';
         $attr['size'] = "size-".esc_attr( $attr['size'] );

         // Allow filtering of the default attributes
         $attributes     = apply_filters( 'wp_default_img_attr', $attr );

         // Build class attribute, considering that maybe some attribute
 was unset via the filter
         $classes  = ' class="';
         $classes .= 'wp-img-default'.esc_attr( $attr['classes'] ? '
 '.$attr['classes'] : '' );
         $classes .= $attr['align'] ? ' '.esc_attr( $attr['align'] ) : '';
         $classes .= $attr['size'] ? ' '.esc_attr( $attr['size'] ).'" ' :
 '" ';

         $image          = "<img
 src='{$url}'{$hwstring}{$classes}{$alt}{$title} />";
         $image          = apply_filters( 'wp_default_img', $image );

         if ( ! $attr['echo'] )
                 return $image;

         return print $image;
 }
 }}}

 Related ticket that pops the whole image size data into
 [http://core.trac.wordpress.org/browser/branches/3.2/wp-
 includes/media.php#L580 get_intermediate_image_sizes();], can be found
 here #18947.

-- 
Ticket URL: <http://core.trac.wordpress.org/ticket/18951>
WordPress Trac <http://core.trac.wordpress.org/>
WordPress blogging software


More information about the wp-trac mailing list