Swing/Zoom のバックアップソース(No.7)
- バックアップ一覧
- 差分 を表示
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- バックアップ を表示
- Swing/Zoom へ行く。
- 1 (2007-05-18 (金) 13:11:04)
- 2 (2011-05-08 (日) 23:30:37)
- 3 (2013-02-22 (金) 18:59:56)
- 4 (2014-04-23 (水) 17:43:51)
- 5 (2014-09-04 (木) 13:54:02)
- 6 (2014-10-07 (火) 17:52:08)
- 7 (2015-10-01 (木) 19:26:04)
- 8 (2016-01-29 (金) 14:01:16)
- 9 (2016-08-12 (金) 15:40:11)
- 10 (2017-10-05 (木) 14:26:51)
- 11 (2019-04-12 (金) 16:44:54)
- 12 (2021-01-23 (土) 21:34:44)
- 13 (2023-12-08 (金) 17:08:03)
--- title: MouseWheelで画像のズームイン・アウト表示 tags: [MouseWheelListener, ImageIcon, JComponent] author: aterai pubdate: 2006-10-16 description: マウスホイールなどで画像をズームイン、ズームアウトします。 --- * 概要 [#g39f1afa] マウスホイールなどで画像をズームイン、ズームアウトします。 #download(https://lh5.googleusercontent.com/_9Z4BYR88imo/TQTW1yBNHvI/AAAAAAAAAp4/ba6eQ-Ul2sg/s800/Zoom.png) * サンプルコード [#n33b6ada] #code(link){{ class ZoomImage extends JComponent implements MouseWheelListener { private final transient ImageIcon icon; private final int iw; private final int ih; private double scale = 1d; public ZoomImage(ImageIcon icon) { super(); this.icon = icon; iw = icon.getIconWidth(); ih = icon.getIconHeight(); addMouseWheelListener(this); } @Override public void paintComponent(Graphics g) { Graphics2D g2 = (Graphics2D) g.create(); g2.scale(scale, scale); g2.drawImage(icon.getImage(), 0, 0, iw, ih, this); g2.dispose(); } @Override public void mouseWheelMoved(MouseWheelEvent e) { changeScale(e.getWheelRotation()); } public void initScale() { scale = 1d; repaint(); } public void changeScale(int iv) { scale = Math.max(.05, Math.min(5d, scale - iv * .05)); repaint(); } } }} * 解説 [#h16d4c28] 上記のサンプルではホイールの上回転で拡大、下回転で縮小しています。 * 参考リンク [#ud24b7c5] - [[JPanelに表示した画像のズームとスクロール>Swing/ZoomingAndPanning]] -- こちらは、`JScrollPane`を使用せずに、画像のズームとスクロールを行うサンプルです。 * コメント [#g84ab533] #comment - `ih = icon.getIconWidth();`の部分は`getIconHeight();`ではありませんでしょうか? -- &user(syo); &new{2007-05-18 (金) 13:11:04}; -- ご指摘ありがとうございます。スクリーンショットもよく見たら中の画像が正方形になってますね(^^;。修正しておきます。 -- &user(aterai); &new{2007-05-18 (金) 13:25:06}; #comment