java分形树_java画分形树实例
欢迎进入Java社区论坛,与200万技术人员互动交流 >>进入 下面是绘制次分形树的方法: import java.awt.Graphics; import javax.swing.JFrame; public class Main extends JFrame { public static void main(String[] args) { Main a = new Main(); a.draw();
欢迎进入Java社区论坛,与200万技术人员互动交流 >>进入
下面是绘制次分形树的方法:
import java.awt.Graphics;
import javax.swing.JFrame;
public class Main extends JFrame {
public static void main(String[] args) {
Main a = new Main();
a.draw();
}
public void draw(){//绘制窗体,添画布
this.setSize(1000,700);//
this.setLocationRelativeTo(null);
this.setDefaultCloseOperation(3);
this.setVisible(true);
Graphics g = this.getGraphics();
}
public void paint(Graphics g){
super.paint(g);
this.Show(500,550,100, Math.PI/2,0,Math.PI/6,25,g);
//(Math.PI为180°)
}
public void Show(double x0,double y0,double l,double a,double b,
double c,double count,Graphics g){
double x2;
double y2;
double x3;
double y3;
double x4;
double y4;
double x5;
double y5;
if(count< 1)
{
return;
}
//判断是否继续进行递归调用,注意:判断一定要放在递归调用之前,否则这段代码将永远不会被执行
x2 = x0 - l*Math.cos(a);
y2 = y0 - l*Math.sin(a);
x3 = x2 - l*Math.cos(b);
y3 = y2 - l*Math.sin(b);
x4 = x0 - l*Math.cos(b);
y4 = y0 - l*Math.sin(b);
x5 = x2 - l*Math.cos(Math.PI/6)*Math.cos(c);
y5 = y2 - l*Math.cos(Math.PI/6)*Math.sin(c);
//计算五个点的位置,以右下点为(X0,Y0)
g.drawLine((int)x0, (int)y0, (int)x2, (int)y2);
g.drawLine((int)x2, (int)y2, (int)x3, (int)y3);
g.drawLine((int)x3, (int)y3, (int)x4, (int)y4);
g.drawLine((int)x4, (int)y4, (int)x0, (int)y0);
g.drawLine((int)x2, (int)y2, (int)x5, (int)y5);
g.drawLine((int)x5, (int)y5, (int)x3, (int)y3);
//划线――注意方法所需要的数据类型
Show(x2,y2,l*Math.cos(Math.PI/6),a+Math.PI/6,b+Math.PI/6,c+Math.PI/6,count-1,g);
Show(x5,y5,l*Math.sin(Math.PI/6),a-Math.PI/3,b-Math.PI/3,c-Math.PI/3,count-1,g);
//进行递归调用(注意传到方法里的点是相对于新正方形的右下点)
}
}
[1] [2]
java分形树_java画分形树实例相关推荐
- java 模拟停车_Java多线程编程小实例模拟停车场系统
下面分享的是一个Java多线程模拟停车场系统的小实例(Java的应用还是很广泛的,哈哈),具体代码如下: Park类 public class Park { boolean []park=new bo ...
- java 画树_JAVA画树
展开全部 画什么都行,这62616964757a686964616fe78988e69d8331333262353463个你得自己实现.我可以给你写一个画树的小程序: ---------------- ...
- java 递归原理_Java中递归原理实例分析
本文实例分析了Java中递归原理.分享给大家供大家参考.具体分析如下: 解释:程序调用自身的编程技巧叫做递归. 程序调用自身的编程技巧称为递归( recursion).递归做为一种算法在程序设计语言中 ...
- java 令牌解析_Java编程guava RateLimiter实例解析
本文主要研究的是Java编程guava RateLimiter的相关内容,具体如下. 场景1 在流量监管中的应用 约定访问速率(CAR)是流量监管常用技术之一,可以应用在端口进和出方向,一般应用在入方 ...
- java sql函数_Java调用Sql存储过程实例讲解
1.使用不带参数的存储过程 使用 JDBC 驱动程序调用不带参数的存储过程时,必须使用 call SQL 转 义序列.不带参数的 call 转义序列的语法如下所示: {call procedure-n ...
- java finally 抛出异常_java抛出异常与finally实例解析
这篇文章主要介绍了java抛出异常与finally实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 代码如下: package test1; ...
- 画王八java代码参数_java画乌龟源代码-郭遥航.doc
java画乌龟源代码-郭遥航.doc /*JAVA基本功小练习用java语言描述小王八用鼠标可以拖动小乌龟进行移动选中乌龟时可以显示小乌龟的腹面*/importjava.awt.*;importjav ...
- java private 命名_java private关键字用法实例
这篇文章主要介绍了java private关键字用法实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 package java04; /* * 问 ...
- file java详解_Java中File的实例详解
Java中File的实例详解 File 代表文件或者目录的类 构造函数 File(File parent,String child)---代表了指定父目录下的指定的子文件或者子目录 File(Stri ...
- java nio 事件_Java NIO原理及实例
Java NIO是在jdk1.4开始使用的,它既可以说成"新I/O",也可以说成非阻塞式I/O.下面是java NIO的工作原理: 1. 由一个专门的线程来处理所有的 IO 事件, ...
最新文章
- 回归模型和时间序列模型中的MAPE指标是什么?MAPE指标解读、MAPE越大越好还是越小越好、使用MAPE指标的注意事项
- 人工智能医疗是把双刃剑,“对抗性攻击”后可导致误判
- spring security 自定义认证登录
- Java JDK11快速下载地址
- C++数组的左右旋转的实现算法(附完整源码)
- php 目录文件大小,利用php怎么对目录文件的大小进行统计
- 数字图像识别笔记(第三章-灰度变换与空间滤波)
- 对Windows学习的总结
- setTimeout()方法和setInterval()方法
- linux每个phy一个接口,mdio
- 微博怎么批量取消所有的关注
- 油菜出现花而不实现象,这是什么原因,该怎样防治?
- python实现模拟身份验证服务器综合系统设计
- 乐行科技获1.08亿元A轮融资,并推出艾特好车 1
- ui sketch_如何在Sketch中设计汽车应用程序设计UI
- 修复 Android 系统问题的 9 款最佳 Android 手机维修软件和应用
- 【渝粤题库】陕西师范大学100111 计算机应用基础 作业 (高起专)
- 恒烁M0+系列CX32L003单片机及其GPIO的操作
- Kafka系列 —— Kafka监控
- LostRoutes项目日志——玩家飞机精灵Fighter解析