首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >AffineTransform:从中心缩放形状

AffineTransform:从中心缩放形状
EN

Stack Overflow用户
提问于 2009-03-27 18:08:40
回答 5查看 26K关注 0票数 7

我正在尝试使用AffineTransform从矩形的中心缩放它。我确信解决方案是显而易见的,但是我不能让它工作!这是我到目前为止测试过的。

代码语言:javascript
复制
import java.awt.Color;
import java.awt.Dimension;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Rectangle;
import java.awt.geom.AffineTransform;

import javax.swing.JOptionPane;
import javax.swing.JPanel;

public class Test extends JPanel {
    Test()
        {
        super(null);
        setOpaque(true);
        setBackground(Color.WHITE);
        setPreferredSize(new Dimension(200,200));
        }
    @Override
    protected void paintComponent(Graphics g1) {
        super.paintComponent(g1);
        Rectangle r= new Rectangle(5,5,getWidth()-10,getHeight()-10);
        double cx= r.getCenterX();
        double cy= r.getCenterY();
        Graphics2D g=(Graphics2D)g1;
        g.setColor(Color.BLACK);
        AffineTransform old= g.getTransform();
        for(double zoom=0.9; zoom>=0.5; zoom-=0.1)
            {
            AffineTransform tr2= new AffineTransform(old);
            tr2.translate(-cx, -cy);
            tr2.scale(zoom, zoom);
            tr2.translate(cx/zoom,cy/zoom);
            g.setTransform(tr2);
            g.draw(r);
            g.setTransform(old);
            }
        }


    public static void main(String[] args) {
        JOptionPane.showMessageDialog(null, new Test());
        }
    }

但是它不工作..。有什么建议吗?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2009-03-30 22:18:16

当你处理矩形时,我明白你的意思。原因是因为最初的平移计算没有考虑到容器对象的大小。

改用下面的代码:

代码语言:javascript
复制
tr2.translate(
    (this.getWidth()/2) - (r.getWidth()*(zoom))/2,
    (this.getHeight()/2) - (r.getHeight()*(zoom))/2
);
tr2.scale(zoom,zoom);
g.setTransform(tr2);

这样做是在缩放之前将矩形平移到面板的中心。在我的测试中,它工作得很好。

票数 6
EN

Stack Overflow用户

发布于 2009-03-27 18:24:56

假设缩放固定了矩形左上角的位置(我认为这是正确的,但我已经很久没有用Java做图形了),您需要将矩形平移到与缩放相反的方向。

代码语言:javascript
复制
tr2.translate(
    r.getWidth()*(1-zoom)/2,
    r.getHeight()*(1-zoom)/2
);
tr2.scale(zoom,zoom);
g.setTransform(tr2);

因此,您可以将矩形向左和向上移动宽度和高度更改的一半。

票数 6
EN

Stack Overflow用户

发布于 2017-08-04 21:43:05

我正在开发一个桌面应用程序来裁剪小甜甜的脸(D.A.Y)。裁剪矩形必须围绕其中心点进行缩放:

代码语言:javascript
复制
import javafx.scene.Cursor;
import javafx.scene.Group;
import javafx.scene.input.MouseEvent;
import javafx.scene.input.ScrollEvent;
import javafx.scene.paint.Color;
import javafx.scene.paint.Paint;
import javafx.scene.shape.Rectangle;

class ResizableRectangle extends Rectangle {

 ResizableRectangle(double x, double y, double width, double height, Group group) {

  super(x, y, width, height);

  // Set scroll listener for crop selection
  group.addEventHandler(ScrollEvent.SCROLL, event -> {
   double zoomFactor = 1.10;
   double deltaY = event.getDeltaY();
   if (deltaY > 0) {
    zoomFactor = 2.0 - zoomFactor;
   }

   super.setX(getX() + (super.getWidth() * (1 - zoomFactor) / 2)); // Set new X position
   super.setWidth(getWidth() * zoomFactor); // Set new Width

   super.setY(getY() + (super.getHeight() * (1 - zoomFactor) / 2)); // Set new Y position
   super.setHeight(getHeight() * zoomFactor); // Set new Height

   event.consume();
  });
 });
}

一般来说,算法的工作原理是这样的:

将新高度转换为:x + (width * (1 - zoomFactor) / 2)

  • Translate y值使用:y + (height * (1 - zoomFactor) / 2)

  • Set
  • to:width * zoomFactor
  • Set new height to:height * zoomFactor
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/690871

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档