Websites don't have a single layout any more. The space you have for an image may be portrait on a laptop, landscape on a tablet, and square on a mobile - particularly if you're using a full-screen image.
If you have to use the same image file in all these contexts, you might not be happy with the results you get when you 'fill' the allocated space with your image. Your subject might be clipped or completely missing, or just really awkward looking.
FocusPoint makes sure your image looks great in any container, by ensuring the 'spare' parts of your image (negative space) are cropped out before the important parts.
For a quick overview of the plugin check out this video by Petr Tichy.
Here are some examples showing the same image cropped a variety of different ways at once. Make sure you play with resizing the browser window to get a feel for what FocusPoint does.
And here is a full screen demo.
The idea is that most images have a focal point or subject that is the most important part of the image. In the case of a traditional portrait photo this would be the subject's face (or specifically the spot right between their eyes). In the image above it's arguably the point halfway between the two people's faces.
FocusPoint requires you to indicate where this focal point is located within your image, and then works in the background to ensure that point is never cropped out.
An image's focus point is made up of x (horizontal) and y (vertical) coordinates. The value of a coordinate can be a number with decimal points anywhere between -1 and +1, where 0 is the centre. X:-1 indicates the left edge of the image, x:1 the right edge. For the y axis, y:1 is the top edge and y:-1 is the bottom.
Confused? Don't worry, there's a handy script included to help you find the focus coordinates of an image with a single click. Check out the helper tool (vastly improved courtesy of @auginator).
You'll need to include jQuery (v1.9 or greater), the FocusPoint script, and FocusPoint css file. Example:
<link rel="stylesheet" href="focuspoint.css">
<script src="jquery.js"></script>
<script src="focuspoint.js"></script>
Specify the image dimensions and focus point coordinates on the image container. The image will take up whatever space is available in the container, so make sure there is some space to fill by setting a height for the container in your CSS. Example:
<div class="focuspoint"
data-focus-x="0.331"
data-focus-y="-0.224"
data-image-w="400"
data-image-h="300">
<img src="image.jpg" alt="" />
</div>
Note: setting data-image-w
and data-image-h
is optional but recommended. Omitting these value means your image will not be positioned correctly inside the frame until it has finished loading, which may cause a visible jump.
Usually the best place for this will be inside your $(document).ready()
function.
//Fire plugin
$('.focuspoint').focusPoint();
That's it!
FocusPoint comes with a few options you can change to suit your needs.
Option | Values | Default | Description |
---|---|---|---|
reCalcOnWindowResize |
true or false |
true |
Whether or not to re-adjust image when the window is resized |
throttleDuration |
Int e.g. 0 or 100 |
17 |
Throttling rate in milliseconds. Set to 0 to disable throttling. |
Example usage:
$('.focuspoint').focusPoint({
throttleDuration: 100 //re-focus images at most once every 100ms.
});
Once you have initialised FocusPoint on an image container you can access FocusPoint methods like this: $(someContainer).data('focusPoint').methodName()
.
Or the shorter way, like this: $(someContainer).focusPoint('methodName')
Function | Description |
---|---|
adjustFocus() |
Re-do calculations and re-position an image in it's frame. Call if container dimensions change. |
windowOn() |
Start window event listener and re-focus image when window is resized |
windowOff() |
Stop re-focusing image when window is resized |