How to Zoom in an Image and Center It

How to zoom in a background image to the center of it

I have been playing around with this a bit. This is what I ended up with.

Here is the logic that I used figuring this out:

  • An image rotates around its center.
  • If I put the image in a container it will cut a part of the image off. The image will still rotate around the center of the image....But that is not the center of the container anymore.
  • Solution: I made the image behave like background: cover; by using min-width: 100%; and min-height: 100%;
  • Solution: I centered the image in the container using flexbox.

Another way of centering might be preferable, since the flexbox also affects other children of the container. So any improvements/comments about that would be welcome :).

html

<div id="wrapper">
<img src="" id="image"/>
</div>

css

@keyframes zoom-effect {
0% {
transform: scale(1) rotate(0deg);}
100% {
transform: scale(4) rotate(360deg);}
}
#wrapper{
height: 250px;
width: 350px;
border: 2px solid green;
display: flex;
justify-content: center;
align-items: center;
overflow: hidden;
}
#image{
z-index: -100;
min-height: 100%;
min-width: 100%;
animation-name: zoom-effect;
animation-duration: 9s;
animation-timing-function: linear;
animation-iteration-count: infinite;
}

Hope it helps :)

How to zoom image from center without using exact position

You can adjust the top and left position at the same time as you enlarge.

-1rem seems to fit nicely.

let image = $('#navigation_bar img');
$('#menu-item-948').hover(function() {
// alert("top :"+position.top +" left : "+ position.left +" right: "+ position.right +" bottom: "+ position.bottom); $(image) .attr("src", "https://matiloos.dts.company/wp-content/uploads/2018/11/Asset-6.png") .animate({ width: "5rem", height: "5rem", top: "-1rem", left: "-1rem" }, 150); $('#menu-item-948').append('<p id="text" >text</p>'); $('#text').css('color', '#55EA00');
}, function() { $(image) .attr("src", "https://matiloos.dts.company/wp-content/uploads/2018/11/Asset-5.png") .animate({ width: "2.5rem", height: "2.5rem", top: 0, left: 0, }, 300); $('#text').remove();});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script><div class="flex-col hide-for-medium flex-center" style="margin-left: 50%; margin-top: 10%">  <ul id="navigation_bar" class="nav header-nav header-bottom-nav nav-center  nav-divided nav-uppercase text-center ">    <li id="menu-item-948" class="menu-item menu-item-type-post_type menu-item-object-page  menu-item-948">      <a href="https://matiloos.dts.company/demos/shop-demos/big-sale/" class="nav-top-link"><img id="pic1" src="https://matiloos.dts.company/wp-content/uploads/2018/11/Asset-5.png" style="position:relative;width: 2.5rem; height: 2.5rem"></a>    </li>  </ul>

How to zoom in an image and center it?

As I said in my comment above, I would avoid the zoom css property and stick to just javascript. I managed to throw together the following code which works pretty well for the first click, really all it needs is a little more dynamically (even a word?).

        <html>              <head>                <script type="text/javascript">               function resizeImg (img)               {              var resize = 150; // resize amount in percentage              var origH  = 200;  // original image height              var origW  = 200; // original image width              var mouseX = event.x;              var mouseY = event.y;              var newH   = origH * (resize / 100) + "px";              var newW   = origW * (resize / 100) + "px";                              // Set the new width and height              img.style.height = newH;              img.style.width  = newW;                            var c = img.parentNode;                            // Work out the new center              c.scrollLeft = (mouseX * (resize / 100)) - (newW / 2) / 2;              c.scrollTop  = (mouseY * (resize / 100)) - (newH / 2) / 2;               }             </script>             <style type="text/css">               #Container {                 position:relative;                 width:200px;                    height:200px;                 overflow:hidden;               }             </style>              </head>              <body>                <div id="Container">                  <img alt="Click to zoom" onclick="resizeImg(this)"                     src="https://picsum.photos/200" />                </div>              </body>            </html>

How to re-center an image once it has been dragged and zoomed in or out

Instead of re-centering the content after scale, use the center point of the content as the scale pivot.
In other words, scale around the center of the content.

Introduce a simple method to calculate the center:

private Point2D getContentCenter() {
Bounds contentBounds = CONTENT.getBoundsInLocal();
return new Point2D(contentBounds.getCenterX(), contentBounds.getCenterY());
}

And scale around it:

private void zoom(ScrollEvent scrollEvent) {
// adds or subtracts to the image's scale based on
// whether user is scrolling backwards or forwards
final double dScale = scrollEvent.getDeltaY() > 0 ? 0.1 : -0.1;
scale += dScale;
Point2D target = getContentCenter();
// applies the zoom to the image
applyZoom(1 + dScale, target);
}

EDIT:
The following ZoomController implements scaling around mouth positions and recentering of the content when the pane is resized :

class ZoomController{

// the plane on which the node is being dragged
private final AnchorPane PLANE;
// the node I want to zoom and drag
private final Node CONTENT;

// the total amount of scaling applied to the CONTENT node
private int scale = 1;

private Point2D lastMousePosition = new Point2D(0, 0);

public ZoomController( AnchorPane plane, Node content ) {
PLANE = plane;
CONTENT = content;

PLANE.heightProperty().addListener((obs, number, t1) -> centerView());
PLANE.widthProperty().addListener((obs, number, t1) -> centerView());

// saves the mouse's position whenever the mouse moves
PLANE.setOnMousePressed(event -> updateMousePosition(event));
PLANE.setOnMouseDragged(drag());

PLANE.setOnScroll(handleScroll());
}

private void updateMousePosition(MouseEvent mouseEvent) {
lastMousePosition = new Point2D(mouseEvent.getX(), mouseEvent.getY());
}

private EventHandler<ScrollEvent> handleScroll() {
return scrollEvent -> {
// filters out the mouse stopping to scroll
if (scrollEvent.getDeltaX() == 0 && scrollEvent.getDeltaY() == 0) return;
// starts zooming
if (scrollEvent.isControlDown()) {
zoom(scrollEvent);
}
};
}

private void zoom(ScrollEvent scrollEvent) {

// adds or subtracts to the image's scale based on
// whether user is scrolling backwards or forwards
final double dScale = scrollEvent.getDeltaY() > 0 ? 0.1 : -0.1;
scale += dScale;

// scale around mouse position
Point2D pivot = CONTENT.parentToLocal(new Point2D(scrollEvent.getX(), scrollEvent.getY()));

//applies the zoom to the image
applyZoom(1 + dScale, pivot);
}

private void applyZoom(final double zoomAmount, Point2D target) {
// applies the necessary scaling to the image...
Scale zoom = new Scale(zoomAmount, zoomAmount);
// ...and centers the scaling to the point where the mouse is located at
zoom.setPivotY(target.getY());
zoom.setPivotX(target.getX());
CONTENT.getTransforms().add(zoom);
}

private EventHandler<MouseEvent> drag() {
return mouseEvent -> {

// calculates the path taken by the mouse...
Point2D newMousePosition = new Point2D(mouseEvent.getX(), mouseEvent.getY());
Point2D mouseTranslation = lastMousePosition.subtract(newMousePosition);
// ...and saves its new position
updateMousePosition(mouseEvent);

// applies the drag
applyDrag(mouseTranslation);
};
}

private void applyDrag(Point2D dragAmount) {
// applies the necessary translation to the image...
Translate drag = new Translate();
// ...based on the mouse's movement
drag.setX(-dragAmount.getX());
drag.setY(-dragAmount.getY());
CONTENT.getTransforms().add(drag);
}

private void centerView() {

// gets the coordinates we need to place the image at for it to be centered
Point2D centerPosition = CONTENT.parentToLocal(getCenterEdge());
Point2D position = getContentPosition();

Point2D translation = centerPosition.subtract(position);
// applies the necessary translation to the image...
Translate translateToCenter = new Translate();
translateToCenter.setX(translation.getX());
translateToCenter.setY(translation.getY());
CONTENT.getTransforms().add(translateToCenter);
}

private Point2D getContentPosition() {
// gets the minimal coordinates of the bounds around the image
// ie: the image's coordinates
Bounds contentBounds = CONTENT.getBoundsInLocal();
return new Point2D(contentBounds.getMinX(), contentBounds.getMinY());
}

private Point2D getCenterEdge() {
// gets the size of the image and the anchor pane it is in...
Point2D contentSize = getContentSize();
Point2D parentSize = getParentSize();
// ...to determine the coordinates at which to place the image for it to be centered
return new Point2D(
(parentSize.getX() - contentSize.getX()) / 2,
(parentSize.getY() - contentSize.getY()) / 2
);
}

private Point2D getContentSize() {
//BoundsInParent: rectangular bounds of this Node which include its transforms
Bounds contentBounds = CONTENT.getBoundsInParent();
return new Point2D(contentBounds.getWidth(), contentBounds.getHeight());
}

private Point2D getParentSize() {//renamed from getAvailableSpace()
// gets the size of the Anchorpane the image is inn
return new Point2D(PLANE.getWidth(), PLANE.getHeight());
}
}


Related Topics



Leave a reply



Submit