One solution is to use a background image centered within an element sized to the cropped dimensions.
.center-cropped {_x000D_
width: 100px;_x000D_
height: 100px;_x000D_
background-position: center center;_x000D_
background-repeat: no-repeat;_x000D_
}
_x000D_
<div class="center-cropped" _x000D_
style="background-image: url('http://placehold.it/200x200');">_x000D_
</div>
_x000D_
img
tagThis version retains the img
tag so that we do not lose the ability to drag or right-click to save the image. Credit to Parker Bennett for the opacity trick.
.center-cropped {_x000D_
width: 100px;_x000D_
height: 100px;_x000D_
background-position: center center;_x000D_
background-repeat: no-repeat;_x000D_
overflow: hidden;_x000D_
}_x000D_
_x000D_
/* Set the image to fill its parent and make transparent */_x000D_
.center-cropped img {_x000D_
min-height: 100%;_x000D_
min-width: 100%;_x000D_
/* IE 8 */_x000D_
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";_x000D_
/* IE 5-7 */_x000D_
filter: alpha(opacity=0);_x000D_
/* modern browsers */_x000D_
opacity: 0;_x000D_
}
_x000D_
<div class="center-cropped" _x000D_
style="background-image: url('http://placehold.it/200x200');">_x000D_
<img src="http://placehold.it/200x200" />_x000D_
</div>
_x000D_
object-fit
/-position
The CSS3 Images specification defines the object-fit
and object-position
properties which together allow for greater control over the scale and position of the image content of an img
element. With these, it will be possible to achieve the desired effect:
.center-cropped {_x000D_
object-fit: none; /* Do not scale the image */_x000D_
object-position: center; /* Center the image within the element */_x000D_
height: 100px;_x000D_
width: 100px;_x000D_
}
_x000D_
<img class="center-cropped" src="http://placehold.it/200x200" />
_x000D_