Waldo is an extension for WordPress and other PHP-based applications that dynamically generates responsive CSS background image styles.
Mobile-first web development is the industry standard these days, and images are one of the leading causes of page bloat and slow loading times, especially on mobile devices and cellular networks. When compressed and appropriately sized images are served, page size and load time decrease drastically.
The state of handling responsive images with regards to web development is in flux, and there is no definitive solution to serving responsive full-cover background images. Waldo presents a solution to this problem, and it does so without utilizing JavaScript or (invalid) inline-styles.
The default configuration and usage guidelines for Waldo are based on WordPress 4.4+ with Advanced Custom Fields 4.4+ or Advanced Custom Fields Pro 5.3+.
Waldo is built to handle ACF's Image Object (which returns an associative array). If you are not using ACF, your image array should be formatted as follows:
$image = array(
'sizes' => array(
'small' => "*small image url*",
'medium' => "*medium image url*",
'large' => "*large image url*",
'xlarge' => "*xlarge image url*"
)
);
Include the following image sizes in your functions.php:
add_image_size('small', width, height);
add_image_size('xlarge', width, height);
Waldo uses a set of common breakpoints to determine the best image size. These image sizes are necessary for Waldo's default configuration to function correctly.
Add the image sizes supported by your theme and their associated min-width media query values in the waldo_sizes array found in waldo.php.
This is important, as the methods in class Waldo() rely on these key/value pairs to properly fetch image references and build the image styles.
For more information on adding support for custom image sizes in WordPress, visit here.
-
Copy waldo-master over to your WordPress theme.
-
Include waldo.php somewhere in your functions.php file.
// load Waldo for dynamic responsive CSS background images include('waldo-master/waldo.php');
-
Enqueue waldo.css in your functions.php file. Ensure the root path of this file is the same as the root path of the theme directory. This file is dynamically generated when Waldo is called. Best practice is to load this stylesheet in the footer to ensure that any styles generated on page load are displayed properly.
function add_waldo_css() { echo '<link rel="stylesheet" id="waldo-css" href="' .get_template_directory_uri() .'/waldo.css">'; } add_action('wp_footer', 'add_waldo_css');
-
Integrate Waldo into your template files.
-
Before each instance where Waldo is to generate background image styles, get the Advanced Custom Field image object, and store to a variable.
// get ACF image object $image = get_field('acf_image_field_name');
-
Set variable $waldo_styles to the function waldoStylesArray() to build styles and save to array.
// set var $waldo_styles to waldoStylesArray $waldo_styles = $waldo->waldoStylesArray();
-
Pass in the ACF image object, a unique name (string), the saved styles array, and a unique class name (string) for this section.
// pass in parameters $waldo_styles = $waldo->waldoStylesArray($image, 'unique-section-name', $waldo_styles, 'unique-section-class-name');
The unique name may be the same as the unique section class name. The name is used as an array key for storage of style information in waldo-styles.php, whereas the class name is used to set the style selector for the rendered CSS in waldo.css.
Complete code example (per Waldo instance):
$image = get_field('acf_image_field_name'); $waldo_styles = $waldo->waldoStylesArray($image, 'unique-section-name', $waldo_styles, 'unique-section-class-name');
-
-
Preload your site cache or click through the pages that utilize the affected template(s) and refresh to view updated responsive image styles.
Note: WordPress does not allow implicit global variable access within some files (header.php, footer.php, and some template/include files). In these cases, the global Waldo variables may need to be explicitly declared at the beginning of the file in question. This may be done in the following manner:
global $waldo, $waldo_styles;
or
$waldo = $GLOBALS['waldo']; $waldo_styles = $GLOBALS['waldo_styles'];
Waldo dynamically generates styles for background images based on media queries and associated optimal image size. Waldo only sets the background-image property, any other styles may be included in the regular stylesheet for the site.
Follow @paper_leaf on Twitter.
© 2016 Paper Leaf Design
License: GNU General Public License - Version 3
Who's the character most well known for always being in the background?
So the question here really should be: "Where's Waldo?" Get it? 😆