MouseWheelで画像のズームイン・アウト表示
Total: 14312
, Today: 3
, Yesterday: 3
Posted by aterai at
Last-modified:
概要
マウスホイールなどで画像をズームイン、ズームアウトします。
Screenshot
Advertisement
サンプルコード
class ZoomImage extends JPanel {
private transient MouseWheelListener handler;
private final transient Image image;
private final int iw;
private final int ih;
private double scale = 1d;
protected ZoomImage(Image image) {
super();
this.image = image;
iw = image.getWidth(this);
ih = image.getHeight(this);
}
@Override public void updateUI() {
removeMouseWheelListener(handler);
super.updateUI();
handler = e -> changeScale(e.getWheelRotation());
addMouseWheelListener(handler);
}
@Override protected void paintComponent(Graphics g) {
super.paintComponent(g);
Graphics2D g2 = (Graphics2D) g.create();
g2.scale(scale, scale);
g2.drawImage(image, 0, 0, iw, ih, this);
g2.dispose();
}
public void initScale() {
scale = 1d;
repaint();
}
public void changeScale(int iv) {
scale = Math.max(.05, Math.min(5d, scale - iv * .05));
repaint();
}
}
View in GitHub: Java, Kotlin解説
- 画像の拡大・縮小表示は
JPanel#paintComponent(...)
をオーバーライドしてGraphics2D#scale(...)
で設定 - 拡大・縮小率はマウスホイールの上方向回転を拡大、下方向回転を縮小として適用