Javaアプレットによる2Dグラフィックサンプル 多角形の描画

Javaグラフィックサンプル(アプレット版):多角形の描画に関する図形描画サンプルです。輪郭線を太くしたり、破線にしたり。図形内のグラデーション、パターン描画等のサンプルを掲載しています。



多角形の描画

このページには、以下のサンプルを掲載しています。 下の項目をクリックをすると各サンプルにジャンプします。 ※2週間以内の新着記事はNewアイコン、更新記事はUpアイコンが表示されます。
  1. 多角形の描画 ( PolygonSample01.java )  
  2. 多角形の描画(塗りつぶし) ( PolygonSample02.java )  
  3. 多角形の描画(太い輪郭線) ( PolygonSample03.java )  
  4. 多角形の描画(太い輪郭線&塗りつぶし) ( PolygonSample04.java )  
  5. 多角形の描画(破線の輪郭線) ( PolygonSample05.java )  
  6. 多角形の描画(破線の輪郭線&塗りつぶし) ( PolygonSample06.java )  
  7. 多角形の描画(グラデーション) ( PolygonSample07.java )  
  8. 多角形の描画(テクスチャーパターン) ( PolygonSample08.java )  
  9. 多角形の描画(回転) ( PolygonSample09.java )  

多角形を描くメソッドには、次のものがあります。
・drawPolygon ・・ 多角形の描画を行います
・fillPolygon ・・ 多角形の描画を行い、中身を塗りつぶします

1. 多角形の描画

[ サンプルプログラムのソースコード - PolygonSample01.java - ]
  1. import javax.swing.JApplet;
  2. import java.awt.Graphics;
  3. import java.awt.Polygon;
  4. public class PolygonSample01 extends JApplet {
  5.   public void paint(Graphics g){
  6.     int[] xpoints = { 10,110, 80,110, 10, 40 };
  7.     int[] ypoints = { 10, 10, 50,110,110, 50 };
  8.     Polygon polygon = new Polygon(xpoints, ypoints, xpoints.length);
  9.     g.drawPolygon(polygon);
  10.   }
  11. }
[ サンプルプログラムの実行結果 ]

[ 関連ページ ]
多角形描画のSwing版サンプル
アプレット版サンプルの他の図形描画
四角形 / 角の丸い四角形 / / 楕円 / 直線 / 連続直線 / ベジェ曲線 / ベジェ曲線を含む図形 / 円弧 / 楕円弧 / 弓形 / 扇形


2. 多角形の描画(塗りつぶし)

[ サンプルプログラムのソースコード - PolygonSample02.java - ]
  1. import javax.swing.JApplet;
  2. import java.awt.Color;
  3. import java.awt.Graphics;
  4. import java.awt.Polygon;
  5. public class PolygonSample02 extends JApplet {
  6.   public void paint(Graphics g){
  7.     g.setColor(Color.RED);
  8.     int[] xpoints = { 10,110, 80,110, 10, 40 };
  9.     int[] ypoints = { 10, 10, 60,110,110, 60 };
  10.     Polygon polygon = new Polygon(xpoints, ypoints, xpoints.length);
  11.     g.fillPolygon(polygon);
  12.   }
  13. }
[ サンプルプログラムの実行結果 ]

[ 関連ページ ]
多角形描画(塗りつぶし)のSwing版サンプル
アプレット版サンプルの他の図形描画
四角形(塗りつぶし) / 角の丸い四角形(塗りつぶし) / 円(塗りつぶし) / 楕円(塗りつぶし) / ベジェ曲線を含む図形(塗りつぶし) / 弓形(塗りつぶし) / 扇形(塗りつぶし)


3. 多角形の描画(太い輪郭線)

[ サンプルプログラムのソースコード - PolygonSample03.java - ]
  1. import javax.swing.JApplet;
  2. import java.awt.BasicStroke;
  3. import java.awt.Graphics;
  4. import java.awt.Graphics2D;
  5. import java.awt.Polygon;
  6. public class PolygonSample03 extends JApplet {
  7.   public void paint(Graphics g){
  8.     Graphics2D g2 = (Graphics2D)g;
  9.     int[] xpoints = { 10,110, 80,110, 10, 40 };
  10.     int[] ypoints = { 10, 10, 60,110,110, 60 };
  11.     Polygon polygon = new Polygon(xpoints, ypoints, xpoints.length);
  12.     g2.setStroke(new BasicStroke(5.0f));
  13.     g2.drawPolygon(polygon);
  14.   }
  15. }
[ サンプルプログラムの実行結果 ]

[ 関連ページ ]
多角形描画(太線)のSwing版サンプル
アプレット版サンプルの他の図形描画
四角形(太線) / 角の丸い四角形(太線) / 円(太線) / 楕円(太線) / 直線(太線) / 連続直線(太線) / ベジェ曲線(太線) / ベジェ曲線を含む図形(太線) / 円弧(太線) / 楕円弧(太線) / 弓形(太線) / 扇形(太線)


4. 多角形の描画(太い輪郭線&塗りつぶし)

[ サンプルプログラムのソースコード - PolygonSample04.java - ]
  1. import javax.swing.JApplet;
  2. import java.awt.BasicStroke;
  3. import java.awt.Color;
  4. import java.awt.Graphics;
  5. import java.awt.Graphics2D;
  6. import java.awt.Polygon;
  7. public class PolygonSample04 extends JApplet {
  8.   public void paint(Graphics g){
  9.     Graphics2D g2 = (Graphics2D)g;
  10.     int[] xpoints = { 10,110, 80,110, 10, 40 };
  11.     int[] ypoints = { 10, 10, 60,110,110, 60 };
  12.     Polygon polygon = new Polygon(xpoints, ypoints, xpoints.length);
  13.     g2.setStroke(new BasicStroke(5.0f));
  14.     g2.setColor(Color.GREEN);
  15.     g2.fillPolygon(polygon);
  16.     g2.setColor(Color.BLACK);
  17.     g2.drawPolygon(polygon);
  18.   }
  19. }
[ サンプルプログラムの実行結果 ]

[ 関連ページ ]
多角形描画(太線&塗りつぶし)のSwing版サンプル
アプレット版サンプルの他の図形描画
四角形(太線&塗りつぶし) / 角の丸い四角形(太線&塗りつぶし) / 円(太線&塗りつぶし) / 楕円(太線&塗りつぶし) / ベジェ曲線を含む図形(太線&塗りつぶし) / 弓形(太線&塗りつぶし) / 扇形(太線&塗りつぶし)


5. 多角形の描画(破線の輪郭線)

[ サンプルプログラムのソースコード - PolygonSample05.java - ]
  1. import javax.swing.JApplet;
  2. import java.awt.BasicStroke;
  3. import java.awt.Graphics;
  4. import java.awt.Graphics2D;
  5. import java.awt.Polygon;
  6. public class PolygonSample05 extends JApplet {
  7.   public void paint(Graphics g){
  8.     Graphics2D g2 = (Graphics2D)g;
  9.     int[] xpoints = { 10,110, 80,110, 10, 40 };
  10.     int[] ypoints = { 10, 10, 60,110,110, 60 };
  11.     Polygon polygon = new Polygon(xpoints, ypoints, xpoints.length);
  12.     float[] dash = { 20.0f, 5.0f,3.0f,5.0f };
  13.     g2.setStroke(new BasicStroke(
  14.         2.0f,
  15.         BasicStroke.JOIN_ROUND,
  16.         BasicStroke.CAP_BUTT,
  17.         1.0f,
  18.         dash,
  19.         0.0f));
  20.     g2.drawPolygon(polygon);
  21.   }
  22. }
[ サンプルプログラムの実行結果 ]

[ 関連ページ ]
多角形描画(破線)のSwing版サンプル
アプレット版サンプルの他の図形描画
四角形(破線) / 角の丸い四角形(破線) / 円(破線) / 楕円(破線) / 直線(破線) / 連続直線(破線) / ベジェ曲線(破線) / ベジェ曲線を含む図形(破線) / 円弧(破線) / 楕円弧(破線) / 弓形(破線) / 扇形(破線)


6. 多角形の描画(破線の輪郭線&塗りつぶし)

[ サンプルプログラムのソースコード - PolygonSample06.java - ]
  1. import javax.swing.JApplet;
  2. import java.awt.BasicStroke;
  3. import java.awt.Color;
  4. import java.awt.Graphics;
  5. import java.awt.Graphics2D;
  6. import java.awt.Polygon;
  7. public class PolygonSample06 extends JApplet {
  8.   public void paint(Graphics g){
  9.     Graphics2D g2 = (Graphics2D)g;
  10.     int[] xpoints = { 10,110, 80,110, 10, 40 };
  11.     int[] ypoints = { 10, 10, 60,110,110, 60 };
  12.     Polygon polygon = new Polygon(xpoints, ypoints, xpoints.length);
  13.     g2.setColor(Color.GREEN);
  14.     g2.fillPolygon(polygon);
  15.     float[] dash = { 20.0f, 5.0f,3.0f,5.0f };
  16.     g2.setStroke(new BasicStroke(
  17.         2.0f,
  18.         BasicStroke.JOIN_ROUND,
  19.         BasicStroke.CAP_BUTT,
  20.         1.0f,
  21.         dash,
  22.         0.0f));
  23.     g2.setColor(Color.BLACK);
  24.     g2.drawPolygon(polygon);
  25.   }
  26. }
[ サンプルプログラムの実行結果 ]

[ 関連ページ ]
多角形描画(破線&塗りつぶし)のSwing版サンプル
アプレット版サンプルの他の図形描画
四角形(破線&塗りつぶし) / 角の丸い四角形(破線&塗りつぶし) / 円(破線&塗りつぶし) / 楕円(破線&塗りつぶし) / ベジェ曲線を含む図形(破線&塗りつぶし) / 弓形(破線&塗りつぶし) / 扇形(破線&塗りつぶし)


7. 多角形の描画(グラデーション)

[ サンプルプログラムのソースコード - PolygonSample07.java - ]
  1. import javax.swing.JApplet;
  2. import java.awt.Color;
  3. import java.awt.GradientPaint;
  4. import java.awt.Graphics;
  5. import java.awt.Graphics2D;
  6. import java.awt.Polygon;
  7. public class PolygonSample07 extends JApplet {
  8.     public void paint(Graphics g){
  9.       Graphics2D g2 = (Graphics2D)g;
  10.       int[] xpoints = { 10,110, 80,110, 10, 40 };
  11.       int[] ypoints = { 10, 10, 60,110,110, 60 };
  12.       Polygon polygon = new Polygon(xpoints, ypoints, xpoints.length);
  13.       GradientPaint gp = new GradientPaint(10,10,Color.GREEN,100,10,Color.BLUE,true);
  14.       g2.setPaint(gp);
  15.       g2.fillPolygon(polygon);
  16.     }
  17. }
[ サンプルプログラムの実行結果 ]

[ 関連ページ ]
多角形描画(グラデーション)のSwing版サンプル
アプレット版サンプルの他の図形描画
四角形(グラデーション) / 角の丸い四角形(グラデーション) / 円(グラデーション) / 楕円(グラデーション) / ベジェ曲線を含む図形(グラデーション) / 弓形(グラデーション) / 扇形(グラデーション) / グラデーションサンプル


8. 多角形の描画(テクスチャーパターン)

[ サンプルプログラムのソースコード - PolygonSample08.java - ]
  1. import javax.swing.JApplet;
  2. import java.awt.Color;
  3. import java.awt.Graphics;
  4. import java.awt.Graphics2D;
  5. import java.awt.Polygon;
  6. import java.awt.Rectangle;
  7. import java.awt.TexturePaint;
  8. import java.awt.image.BufferedImage;
  9. public class PolygonSample08 extends JApplet {
  10.   
  11.   public void paint(Graphics g){
  12.     Graphics2D g2 = (Graphics2D)g;
  13.     int[] xpoints = { 10,110, 80,110, 10, 40 };
  14.     int[] ypoints = { 10, 10, 60,110,110, 60 };
  15.     Polygon polygon = new Polygon(xpoints, ypoints, xpoints.length);
  16.     BufferedImage bi = new BufferedImage(10,10,BufferedImage.TYPE_INT_RGB);
  17.     Graphics2D bg = bi.createGraphics();
  18.     Rectangle r = new Rectangle(0,0,10,10);
  19.     bg.setColor(Color.ORANGE);
  20.     bg.fillRect(0, 0, 10, 10);
  21.     bg.setColor(Color.BLUE);
  22.     bg.drawLine(0, 0, 10, 0);
  23.     bg.drawLine(0, 0, 0, 5);
  24.     bg.drawLine(0, 5, 10, 5);
  25.     bg.drawLine(5, 5, 5, 10);
  26.     TexturePaint tp = new TexturePaint(bi,r);
  27.     g2.setPaint(tp);
  28.     g2.fillPolygon(polygon);
  29.   
  30.   }
  31. }
[ サンプルプログラムの実行結果 ]

[ 関連ページ ]
多角形描画(テクスチャーパターン)のSwing版サンプル
アプレット版サンプルの他の図形描画
四角形(テクスチャーパターン) / 角の丸い四角形(テクスチャーパターン) / 円(テクスチャーパターン) / 楕円(テクスチャーパターン) / ベジェ曲線を含む図形(テクスチャーパターン) / 弓形(テクスチャーパターン) / 扇形(テクスチャーパターン) / いろいろなテクスチャーパターン


9. 多角形の描画(回転)

[ サンプルプログラムのソースコード - PolygonSample09.java - ]
  1. import javax.swing.JApplet;
  2. import java.awt.Color;
  3. import java.awt.Graphics;
  4. import java.awt.Graphics2D;
  5. import java.awt.Polygon;
  6. import java.awt.Rectangle;
  7. import java.awt.TexturePaint;
  8. import java.awt.geom.AffineTransform;
  9. import java.awt.image.BufferedImage;
  10. public class PolygonSample09 extends JApplet {
  11.   private static final long serialVersionUID = 1L;
  12.   public void paint(Graphics g){
  13.     Graphics2D g2 = (Graphics2D)g;
  14.     int[] xpoints = { 20,100, 75,100, 20, 45 };
  15.     int[] ypoints = { 20, 20, 60,100,100, 60 };
  16.     Polygon polygon = new Polygon(xpoints, ypoints, xpoints.length);
  17.     BufferedImage bi = new BufferedImage(10,10,BufferedImage.TYPE_INT_RGB);
  18.     Graphics2D bg = bi.createGraphics();
  19.     Rectangle r = new Rectangle(0,0,10,10);
  20.     bg.setColor(Color.ORANGE);
  21.     bg.fillRect(0, 0, 10, 10);
  22.     bg.setColor(Color.BLUE);
  23.     bg.drawLine(0, 0, 10, 0);
  24.     bg.drawLine(0, 0, 0, 5);
  25.     bg.drawLine(0, 5, 10, 5);
  26.     bg.drawLine(5, 5, 5, 10);
  27.     TexturePaint tp = new TexturePaint(bi,r);
  28.     g2.setPaint(tp);
  29.     AffineTransform at = new AffineTransform();
  30.     at.setToRotation(45*Math.PI/180.0f, 60,60);
  31.     g2.setTransform(at);
  32.     g2.fillPolygon(polygon);
  33.   }
  34. }
[ サンプルプログラムの実行結果 ]

[ 関連ページ ]
多角形描画(回転)のSwing版サンプル
アプレット版サンプルの他の図形描画
四角形(回転) / 角の丸い四角形(回転) / 円(回転) / 楕円(回転) / ベジェ曲線を含む図形(回転) / アニメーションサンプル(図形の回転)




最終更新日:2019/02/13

2015-03-01からの訪問者数
  2910 人