Swing/RotatedIcon の変更点
- 追加された行はこの色です。
- 削除された行はこの色です。
- Swing/RotatedIcon へ行く。
- Swing/RotatedIcon の差分を削除
---
category: swing
folder: RotatedIcon
title: Iconを回転する
tags: [Icon, AffineTransform]
author: aterai
pubdate: 2012-06-11T15:18:47+09:00
description: 画像ファイルから90、180、270度回転したIconを作成します。
image: https://lh4.googleusercontent.com/-OK_vUTiAiCA/T9WIzXvRm9I/AAAAAAAABNk/ubus049qH04/s800/RotatedIcon.png
---
* 概要 [#summary]
画像ファイルから`90`、`180`、`270`度回転した`Icon`を作成します。
#download(https://lh4.googleusercontent.com/-OK_vUTiAiCA/T9WIzXvRm9I/AAAAAAAABNk/ubus049qH04/s800/RotatedIcon.png)
* サンプルコード [#sourcecode]
#code(link){{
class RotateIcon implements Icon {
private final Dimension d = new Dimension();
private final Image image;
private AffineTransform trans;
protected RotateIcon(Icon icon, int rotate) {
if (rotate % 90 != 0) {
throw new IllegalArgumentException(
rotate + ": Rotate must be (rotate % 90 == 0)");
}
d.setSize(icon.getIconWidth(), icon.getIconHeight());
image = new BufferedImage(d.width, d.height, BufferedImage.TYPE_INT_ARGB);
Graphics g = image.getGraphics();
icon.paintIcon(null, g, 0, 0);
g.dispose();
int numquadrants = (rotate / 90) % 4;
if (numquadrants == 1 || numquadrants == -3) {
trans = AffineTransform.getTranslateInstance(d.height, 0);
int v = d.width;
d.width = d.height;
d.height = v;
} else if (numquadrants == -1 || numquadrants == 3) {
trans = AffineTransform.getTranslateInstance(0, d.width);
int v = d.width;
d.width = d.height;
d.height = v;
} else if (Math.abs(numquadrants) == 2) {
trans = AffineTransform.getTranslateInstance(d.width, d.height);
} else {
trans = AffineTransform.getTranslateInstance(0, 0);
}
trans.rotate(Math.toRadians(90d * numquadrants));
// trans.quadrantRotate(numquadrants);
}
@Override public void paintIcon(Component c, Graphics g, int x, int y) {
Graphics2D g2 = (Graphics2D) g.create();
g2.translate(x, y);
g2.drawImage(image, trans, c);
g2.dispose();
}
@Override public int getIconWidth() {
return d.width;
}
@Override public int getIconHeight() {
return d.height;
}
}
}}
* 解説 [#explanation]
- `Default`
-- 幅高さ: `83x100`
- `Rotate`: `180`
-- 幅高さ: `83x100`
-- 上下反転と同等: [[AffineTransformOpで画像を反転する>Swing/AffineTransformOp]]
- `Rotate`: `90`(時計回りに`90`度)
-- 幅高さ: `100x83`(元画像の幅高さを入れ替え)
-- 左上を原点に`90`度回転し、元画像の高さだけ`X`軸プラス方向に移動
- `Rotate`: `-90`(反時計回りに`90`度)
-- 幅高さ: `100x83`(元画像の幅高さを入れ替え)
-- 左上を原点に`270`度回転し、元画像の幅だけ`Y`軸プラス方向に移動
----
- `AffineTransform.getQuadrantRotateInstance(...)`メソッドを使用するサンプルは[[Iconを指定した数の四分円だけ回転して表示する>Swing/QuadrantRotateIcon]]に移動
* 参考リンク [#reference]
- %%[http://duke.kenai.com/iconSized/index.html Duke Images: iconSized]%%
- [[Iconを指定した数の四分円だけ回転して表示する>Swing/QuadrantRotateIcon]]
- [[AffineTransformOpで画像を反転する>Swing/AffineTransformOp]]
- [[Mouseで画像を移動、回転>Swing/MouseDrivenImageRotation]]
- [[JTabbedPaneのタブタイトル文字列を回転して縦組表示する>Swing/RotatedVerticalTextTabs]]
- [[Animated Gifを回転して表示する>Swing/RotateAnimatedGifImageIcon]]
* コメント [#comment]
#comment
#comment