Jave 鼠标点击画太极 PaintTaiji (整理)

简介: 1 package demo; 2 3 /** 4 * Jave 鼠标点击画太极 PaintTaiji (整理) 5 * 声明: 6 * 又是一份没有注释的代码,而且时间已经久远了,不过代码很短,解读起来应该 7 * 不会很麻烦。
  1 package demo;
  2 
  3 /**
  4  *                 Jave 鼠标点击画太极 PaintTaiji (整理)
  5  * 声明:
  6  *     又是一份没有注释的代码,而且时间已经久远了,不过代码很短,解读起来应该
  7  * 不会很麻烦。
  8  *
  9  *                                           2016-1-2 深圳 南山平山村 曾剑锋
 10  */
 11 
 12 import java.awt.Color;
 13 import java.awt.Graphics;
 14 import java.awt.event.MouseEvent;
 15 import java.awt.event.MouseListener;
 16 import java.util.ArrayList;
 17 
 18 import javax.swing.JFrame;
 19 import javax.swing.JPanel;
 20 
 21 public class PaintTaiji extends JPanel{
 22     private static final long serialVersionUID = 1L;
 23     //所有的数据都是依照
 24     static int  centerX = 600/2;
 25     static int centerY = centerX;
 26     ArrayList<Taiji> taijis = new ArrayList<Taiji>();
 27     
 28     
 29     public PaintTaiji() {
 30         startRun();
 31         this.addMouseListener(new MouseListener() {
 32             
 33             @Override
 34             public void mouseReleased(MouseEvent e) {
 35                 // TODO Auto-generated method stub
 36                 
 37             }
 38             
 39             @Override
 40             public void mousePressed(MouseEvent e) {
 41                 int mouseX = e.getX();
 42                 int mouseY = e.getY();
 43                 taijis.add(new Taiji(mouseX, mouseY));
 44             }
 45             
 46             @Override
 47             public void mouseExited(MouseEvent e) {
 48                 // TODO Auto-generated method stub
 49                 
 50             }
 51             
 52             @Override
 53             public void mouseEntered(MouseEvent e) {
 54                 // TODO Auto-generated method stub
 55                 
 56             }
 57             
 58             @Override
 59             public void mouseClicked(MouseEvent e) {
 60             }
 61         });
 62     }
 63     @Override
 64     public void paint(Graphics graphics) {
 65         super.paint(graphics);
 66         this.setBackground(Color.red);
 67         for (Taiji taiji : taijis) {
 68             taiji.paint(graphics);
 69         }
 70     }
 71     
 72     public static void main(String[] args) {
 73         JFrame jFrame = new JFrame();
 74         //设置JFrame标题
 75         jFrame.setTitle("TaiJi");
 76         //设置JFrame的大小
 77         jFrame.setSize(centerX*2, centerY*2);
 78         jFrame.setLocationRelativeTo(null);
 79         jFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
 80         
 81         PaintTaiji taiji = new PaintTaiji();
 82         jFrame.add(taiji);
 83 
 84         //将窗口设置为可见
 85         jFrame.setVisible(true);
 86     }
 87     public void startRun() {
 88         new Thread(){
 89             public void run() {
 90                 while(true){
 91                    try{
 92                            for (Taiji taiji : taijis) {
 93                            taiji.angle += taiji.angleStep;
 94                            }
 95                         Thread.sleep(20);
 96                     } catch (InterruptedException e) {
 97                         e.printStackTrace();
 98                     }
 99                     repaint();
100                 }
101             };
102         }.start();
103     }
104 }
105 class Taiji{
106     int centerX;
107     int centerY;
108     int extendCircleSemi = (int)(Math.random()*200)+1;
109     int innerCircleSemi = extendCircleSemi/2;
110     //旋转角度,值由线程维护,大约每20ms自加1
111     int angle = 0;
112     int angleStep = (int)(Math.random()*6)+1;
113     public Taiji(int x, int y) {
114         centerX = x;
115         centerY = y;
116     }
117     
118     public void paint(Graphics graphics ) {
119         graphics.setColor(    Color.white);
120         graphics.fillArc(    centerX-extendCircleSemi,
121                             centerY-extendCircleSemi,
122                             extendCircleSemi*2,
123                             extendCircleSemi*2, 0+angle, 180);
124         graphics.setColor(    Color.black);
125         graphics.fillArc(    centerX-extendCircleSemi,
126                             centerY-extendCircleSemi,
127                             extendCircleSemi*2,
128                             extendCircleSemi*2,
129                             180+angle, 180);
130         graphics.fillArc(    centerX+(int)(Math.cos(Math.PI*angle/180)*innerCircleSemi)-innerCircleSemi,
131                             centerY-(int)(Math.sin(Math.PI*angle/180)*innerCircleSemi)-innerCircleSemi,
132                             innerCircleSemi*2,
133                             innerCircleSemi*2,
134                             0,
135                             360);
136         graphics.setColor(    Color.white);
137         graphics.fillArc(    centerX+(int)(Math.cos(Math.PI*angle/180)*innerCircleSemi)-innerCircleSemi/2,
138                             centerY-(int)(Math.sin(Math.PI*angle/180)*innerCircleSemi)-innerCircleSemi/2,
139                             innerCircleSemi,
140                             innerCircleSemi,
141                             0,
142                             360);
143         graphics.setColor(    Color.white);
144         graphics.fillArc(    centerX-(int)(Math.cos(Math.PI*angle/180)*innerCircleSemi)-innerCircleSemi,
145                             centerY+(int)(Math.sin(Math.PI*angle/180)*innerCircleSemi)-innerCircleSemi,
146                             innerCircleSemi*2,
147                             innerCircleSemi*2,
148                             0,
149                             360);
150         graphics.setColor(    Color.black);
151         graphics.fillArc(    centerX-(int)(Math.cos(Math.PI*angle/180)*innerCircleSemi)-innerCircleSemi/2,
152                             centerY+(int)(Math.sin(Math.PI*angle/180)*innerCircleSemi)-innerCircleSemi/2,
153                             innerCircleSemi,
154                             innerCircleSemi,
155                             0,
156                             360);
157     }
158 }

 效果如图:

  

  

目录
相关文章
|
4月前
|
前端开发
前端知识笔记(十三)———单全选框控制方法,炒鸡无敌方便!!!
前端知识笔记(十三)———单全选框控制方法,炒鸡无敌方便!!!
15 0
|
5月前
|
存储
SwiftUI完成了伸缩式导航栏!好家伙,还不收藏一波~
SwiftUI完成了伸缩式导航栏!好家伙,还不收藏一波~
45 0
|
6月前
CocosCreator3.8研究笔记(二十三)CocosCreator 动画系统-动画编辑器相关功能面板说明
CocosCreator3.8研究笔记(二十三)CocosCreator 动画系统-动画编辑器相关功能面板说明
|
10月前
|
存储 Java API
一个精美的主界面窗口功能的设计和实现原来如此简单,万字肝爆
一个精美的主界面窗口功能的设计和实现原来如此简单,万字肝爆
69 0
给typecho添加社会主义核心价值观24字特效,鼠标点击出现富强,民主,文明等等12组词
给typecho添加社会主义核心价值观24字特效,鼠标点击出现富强,民主,文明等等12组词
234 0
|
IDE 测试技术 开发工具
AirtestIDE这个隐藏的小助手,还没用过你就亏啦!
AirtestIDE这个隐藏的小助手,还没用过你就亏啦!
192 0
截图如何能截到鼠标?脑洞小方法
截图如何能截到鼠标?脑洞小方法
253 0
WordPress 5文章编辑真难用 换回老版经典编辑器教程
WordPress 5文章编辑真难用 换回老版经典编辑器教程 WordPress 5 正式采用了全新的“Block Editor”编辑器,从而替换了原有“Classic Editor”编辑器,相信有很多人和子凡一样会不习惯或者不喜欢新编辑器,那么新版 WordPress 该如何换回原来的 WordPress 编辑器呢? 不可否认 WordPress 还是非常人性化的,至少会考虑和兼顾更多的用户,不然子凡也不可能青睐 WordPress,所以及时 WordPress 5更换了全新的编辑器,但是也依旧给大家提供了快速便捷切换到原编辑器的插件:“Classic Editor”。
4638 0