package demo;

 import java.awt.Color;
import java.awt.Graphics; import javax.swing.JFrame;
import javax.swing.JPanel; /**
* Java Cardioid 心脏形曲线 (整理)
* 这是以前看到有关Cardioid一个故事之后,觉得好玩,那时把它实现了。
*
* 2016-1-2 深圳 南山平山村 曾剑锋
*/
public class Cardioid extends JPanel{
/**
* <ol>
* <li>centerX:代表x轴中心点坐标
* <li>centerY:代表y轴中心店坐标
* </ol>
* 整个窗口的长、宽等于2*centerX、2*centerY,这么做的目的是保证数据的统一性修改
* 当然你也可以考虑使用长、宽来表示,然后对他们进行取一半得到中心店坐标。
*
*/
static int centerX = 600/2;
static int centerY = 600/2;
/**
* angle:主要用于角度计算,下面程序中的for循环里的变量,360一个周期
*/
int angle;
/**
* <ol>
* <li>a:窗口中有2个心形图,a是其中一个的幅值
* <li>b:窗口中有2个心形图,b是其中一个的幅值
* </ol>
* 2个心形图,2个幅值,但初始值是不一样的。
*/
int a = 0;
int b = 50;
/**
* 构造函数调用start()函数。<br>
* 作用:开启一个线程,主要用于调整a、b的值,并刷新界面。
*/
public Cardioid() {
start();
}
/**
* 重写paint()<br>
* 程序流程:<ol>
* <li>调用父类paint方法、并设置背景颜色为黑色
* <li>用for循环画两个发散的心形图
* </ol>
*/
@Override
public void paint(Graphics graphics) {
super.paint(graphics);
this.setBackground(Color.black);
graphics.setColor(Color.red);
/*
* 这里是难点,主要是因为需要对坐标进行定位,下面是获取x、y的坐标公式,你可以在网上查到
* x=a*(2*sin(t)-sin(2*t))
* y=a*(2*cos(t)-cos(2*t))
* 这里的x、y和网上的公式对调了,主要是因为需要进行y=x对称,网上的图是横着的,这个图是正着的。
* sin()函数传入的是弧度制,所以需要通过angle*Math.PI/180,将角度值换成幅度值
* 其中的500主要是用于坐标调整的,没有理由,是我自己试出来的,我也没有去深究为什么,因为功能完成了。
*/
for (angle = 0; angle < 360; angle++) {
graphics.drawLine(
centerY+(int)(a*(2*Math.sin(angle*Math.PI/180)-Math.sin(2*angle*Math.PI/180))),
500 -(centerX+(int)(a*(2*Math.cos(angle*Math.PI/180)-Math.cos(2*angle*Math.PI/180)))),
centerY+(int)((a+3)*(2*Math.sin((angle)*Math.PI/180)-Math.sin(2*(angle)*Math.PI/180))),
500 -(centerX+(int)((a+3)*(2*Math.cos((angle)*Math.PI/180)-Math.cos(2*(angle)*Math.PI/180)))));
}
for (angle = 0; angle < 360; angle++) {
graphics.drawLine(
centerY+(int)(b*(2*Math.sin(angle*Math.PI/180)-Math.sin(2*angle*Math.PI/180))),
500 -(centerX+(int)(b*(2*Math.cos(angle*Math.PI/180)-Math.cos(2*angle*Math.PI/180)))),
centerY+(int)((b+3)*(2*Math.sin((angle)*Math.PI/180)-Math.sin(2*(angle)*Math.PI/180))),
500 -(centerX+(int)((b+3)*(2*Math.cos((angle)*Math.PI/180)-Math.cos(2*(angle)*Math.PI/180)))));
}
}
/**
* 创建一个匿名线程,线程主要完成以下事情:<ol>
* <li>改变a、b的值,相当于改变心形线的幅值;
* <li>延时20ms;
* <li>刷新界面repaint();
* </ol>
*/
public void start() {
new Thread(new Runnable() { @Override
public void run() {
while (true) {
try {
if (a++ >100) {
a = 0;
}
if (b++ >100) {
b = 0;
}
Thread.sleep(20);
repaint();
} catch (InterruptedException e) {
e.printStackTrace();
}
} }
}).start();
}
/**
* 主函数完成以下内容:<ol>
* <li>初始化jframe窗口;
* <li>创建cardioid,并将cardioid填充到jFrame中;
* <li>设置jFrame可见。
* </ol>
*/
public static void main(String[] args) {
JFrame jFrame = new JFrame();
jFrame.setTitle("Cardioid");
jFrame.setSize(centerX*2, centerY*2);
jFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jFrame.setLocationRelativeTo(null); Cardioid cardioid = new Cardioid();
jFrame.add(cardioid);
jFrame.setVisible(true);
}
}

Java Cardioid 心脏形曲线 (整理)的更多相关文章

  1. Java 动态写轮眼 SharinganJPanel (整理)

      /** * Java 动态写轮眼 SharingganJPanel (整理) * * 2016-1-2 深圳 南山平山村 曾剑锋 * 设计声明: * 1.虽然岸本是日本人,而我个人作为其模仿者,依 ...

  2. Java 动态眨眼 EyesJPanel (整理)

    /** * Java 动态眨眼 EyesJPanel (整理) * * 2016-1-2 深圳 南山平山村 曾剑锋 * 注意事项: * 1.本程序为java程序,同时感谢您花费宝贵的时间来阅读本文档: ...

  3. Java 动态太极图 DynamicTaiChi (整理)

    package demo; import java.awt.Color; import java.awt.Graphics; import javax.swing.JFrame; import jav ...

  4. Java笔试面试题整理第八波

    转载至:http://blog.csdn.net/shakespeare001/article/details/51388516 作者:山代王(开心阳) 本系列整理Java相关的笔试面试知识点,其他几 ...

  5. Java笔试面试题整理第六波(修正版)

    转载至:http://blog.csdn.net/shakespeare001/article/details/51330745 作者:山代王(开心阳) 本系列整理Java相关的笔试面试知识点,其他几 ...

  6. Java笔试面试题整理第五波

    转载至:http://blog.csdn.net/shakespeare001/article/details/51321498 作者:山代王(开心阳) 本系列整理Java相关的笔试面试知识点,其他几 ...

  7. Java笔试面试题整理第四波

    转载至:http://blog.csdn.net/shakespeare001/article/details/51274685 作者:山代王(开心阳) 本系列整理Java相关的笔试面试知识点,其他几 ...

  8. Java笔试面试题整理第三波

    转载至:http://blog.csdn.net/shakespeare001/article/details/51247785 作者:山代王(开心阳) 本系列整理Java相关的笔试面试知识点,其他几 ...

  9. Java笔试面试题整理第二波

    转载至:http://blog.csdn.net/shakespeare001/article/details/51200163 作者:山代王(开心阳) 本系列整理Java相关的笔试面试知识点,其他几 ...

随机推荐

  1. SGU 104

    104. Little shop of flowers time limit per test: 0.25 sec. memory limit per test: 4096 KB PROBLEM Yo ...

  2. Android Handler的使用

    大家好我们这一节讲的是Android Handler的使用,在讲Handler之前,我们先提个小问题,就是如何让程序5秒钟更新一下Title. 首先我们看一下习惯了Java编程的人,在不知道Handl ...

  3. poj 3615(floyd变形)

    题目链接:http://poj.org/problem?id=3615 思路:map[i][j]表示顶点i,j之间的最高的障碍物,于是题目要求的是最高障碍物的最小值,不就是min(map[i][j], ...

  4. JS中的内部类

     js内部类 javascript中本身有提供一些可以直接使用的类,这种类就是内部类.主要有:Object.Array.Math.Boolean.String.Number.Date.RegExp. ...

  5. JDK环境变量解析

    设置环境变量 在java 中需要设置三个环境变量(1.5之后不用再设置classpath了,但个人强烈建议继续设置以保证向下兼用问题)JDK安装完成之后我们来设置环境变量:右击“我的电脑”,选择“属性 ...

  6. 如何使用JMeter来实现更大批量的并发的解决方案(即如何设置controller和Agent)

    http://www.testwo.com/blog/6373 近期在用JMeter进行负载测试的 时候,发现使用单台机器模拟测试超过比如500个进程的并发就有些力不从心或者说不能如实的反应实际情况, ...

  7. SSH连接不上Linux的解决方法

    SSH连接不上Linux的解决方法: 连续弄了几次,今天早上终于把SSH连接虚拟机连接不通的问题解决了. 先简单说下概要: 主机装的是XP系统,虚拟机用的是red hat Linux. 我用的是nat ...

  8. wordcount数据流过程解析

    (1)执行hadoopFile()操作,其中有生成HadoopRDD的new 方法.然后执行map方法.pair => pair._2.toString,只对Value值进行操作.在textFi ...

  9. Linux内核同步机制之(三):memory barrier【转】

    转自:http://www.wowotech.net/kernel_synchronization/memory-barrier.html 一.前言 我记得以前上学的时候大家经常说的一个词汇叫做所见即 ...

  10. Solr的一些查询参数

    fl: 是逗号分隔的列表,用来指定文档结果中应返回的 Field 集.默认为 “*”,指所有的字段. defType: 指定query parser,常用defType=lucene, defType ...