画完三角形再画谢尔宾斯基地毯

画完三角形再画谢尔宾斯基地毯照样废话不说,看代码看注释importjava.awt.Color;importjava.awt.Dimension;importjava.awt.Graphics;importjava.awt.Toolkit;importjava.awt.event.MouseAdapter;importjava.awt.event.MouseEvent;import…

大家好,又见面了,我是你们的朋友全栈君。

照样废话不说,看代码看注释

import java.awt.Color;
import java.awt.Dimension;
import java.awt.Graphics;
import java.awt.Toolkit;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import javax.swing.JFrame;
import javax.swing.JPanel;

/**
 *通过递归画出谢尔宾斯基地毯
 * @author LONG
 *
 */
public class Retc extends JFrame {
	/**
	 * 
	 */
	private Dimension di = null;		//声明Dimension类型的变量,来储存屏幕的尺寸
	private Graphics gr = null;		//声明画布类型变量,来储存面板的画布对象
	private boolean isSuccessful = true;	//用来判断最外面的边框是否已经连接
	private static final long serialVersionUID = 1L;
	
	/**
	 * 程序主函数
	 * @param args
	 */
	public static void main(String[] args){
		Retc ke = new Retc();
		ke.showFrame();
	}
	
	/**
	 * 展示窗体,设置窗体的函数,包括得到画布和添加监听器等
	 */
	public void showFrame(){
		this.setTitle("谢尔宾斯基地毯");
		Toolkit tl = Toolkit.getDefaultToolkit();		//得到工具箱
		di = tl.getScreenSize();					//得到屏幕尺寸
		this.setSize(di.width,di.height);		//设置窗体大小,和屏幕大小一样
		this.setDefaultCloseOperation(3);			//设置窗体退出时关闭
		
		JPanel jp_draw = new JPanel();				//创建绘画时会用到的面板
		jp_draw.setPreferredSize(new Dimension(di.width,di.height));			//设置面板的大小和窗体的大小一样
		jp_draw.setBackground(Color.WHITE);			//将背景色设为白色
		this.setResizable(false);				//不可改变窗体的大小
		this.add(jp_draw);				//将面板添加到窗体上
		this.setVisible(true);				//将窗体可视化,然后再得到画布
		
		gr = jp_draw.getGraphics();			//得到面板上的画布对象
		jp_draw.addMouseListener(new MouseAdapter(){		//给面板添加鼠标监听器
			public void mousePressed(MouseEvent e){
				doSomething();		//调用初始化的函数
			}
		});
	}
	
	/**
	 * 初始化整个窗体,因为在调用递归时有差别,所以单独列出来
	 */
	public void doSomething(){
		draw(0,0,di.width,di.height);
	}
	
	/**
	 * 用于实现递归的函数
	 * @param x1	矩形块的左上角x坐标
	 * @param y1	矩形块的左上角y坐标
	 * @param x2	矩形块的右下角x坐标
	 * @param y2	矩形块的右下角y坐标
	 */
	public void draw(int x1,int y1,int x2,int y2){
		//为了清楚看见进行的过程,使用线程控制
		try {
			Thread.sleep(1);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		
		
		//判断语句,来判断是否已经将最外面的边框连接起来,如果已经连接,则让isSuccessful为false
		if(isSuccessful){
			gr.drawLine(x1, y1, x1, y2);
			gr.drawLine(x1, y1, x2, y1);
			gr.drawLine(x1, y2, x2, y2);
			gr.drawLine(x2, y1, x2, y2);
			isSuccessful = false;
		}
		
		//用来终止递归的判断条件,通过判断矩形两个对角的横坐标之差是否大于10个像素,如果小于等于,则终止
		//如果不进行终止,则会出现栈溢错误
		if(Math.abs(x2 - x1) > 10){
			
			int p_x1 = (x2 - x1)/3 + x1;		//计算得到矩形上边三分之一处的x坐标
			int p_y1 = y1;						//计算得到矩形上边三分之一处的y坐标
			
			int p_x2 = (x2 - x1)*2/3 + x1;		//计算得到矩形上边三分之二处的x坐标
			int p_y2 = y1;					//计算得到矩形上边三分之二处的y坐标
			
			int p_x3 = x2;					//计算得到矩形右边三分之一处的x坐标,和x2的x坐标相同
			int p_y3 = (y2 - y1)/3 + y1;		//计算得到矩形右边三分之一处的y坐标
			
			int p_x4 = x2;						//计算得到矩形右边三分之二处的x坐标
			int p_y4 = (y2 - y1)*2/3 + y1;		//计算得到矩形右边三分之二处的y坐标
			
			//连接上面得到和可以推出的点,将原来的矩形分为九块
			gr.drawLine(p_x1, p_y1, p_x1, y2);
			gr.drawLine(p_x2, p_y2, p_x2, y2);
			gr.drawLine(p_x3, p_y3, x1, p_y3);
			gr.drawLine(p_x4, p_y4, x1, p_y4);
			//将中心处的矩形填充起来,为了绚烂用随机颜色
			gr.setColor(new Color((int)(Math.random()*255),(int)(Math.random()*255),(int)(Math.random()*255)));
			gr.fillRect(p_x1, p_y3, Math.abs(p_x2 - p_x1), Math.abs(p_y4 - p_y3));
			
			draw(x1,y1,p_x1,p_y3);			//递归画出左上角第一个
			draw(p_x1,p_y1,p_x2,p_y3);	//递归画出上边中间那个矩型
			draw(p_x2,p_y2,p_x3,p_y3);	//递归画出右上角的那个矩形
			draw(p_x2,p_y3,p_x4,p_y4);	//递归画出右边中间那一个
			draw(p_x2,p_y4,x2,y2);		//递归画出右下角那一个矩形
			draw(p_x1,p_y4,p_x2,y2);		//递归画出下面中间那一个
			draw(x1,p_y4,p_x1,y2);		//递归画出左下角那一个矩形
			draw(x1,p_y3,p_x1,p_y4);	//递归画出左边中间那一个矩形
		}
		
		
	}
}

 。。。嘿嘿

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/158458.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ubuntu16.04安装搜狗输入法_ubuntu18.04安装搜狗输入法

    ubuntu16.04安装搜狗输入法_ubuntu18.04安装搜狗输入法首先安装fcitx一、检测是否安装fcitx首先检测是否有fcitx,因为搜狗拼音依赖fcitx>fcitx提示:程序“fcitx”尚未安装。您可以使用以下命令安装:>sudoapt-getinstallfcitx-bin二、安装fcitxsudoapt-getinstallfcitx-bin相关的依赖库和框架都会自动安装上。sudoapt-getinstall…

    2022年10月18日
    2
  • linux应急响应检查项_centos7查看服务状态

    linux应急响应检查项_centos7查看服务状态上一篇文章说到Windows的应急响应排查,本篇文章就来说说Linux的应急响应排查。首先,前期交互这部分的内容还是不能少的,毕竟掌握的信息越多,排查的思路就越清晰。Part1熟悉主机环境 uname-a cat/proc/version lsb_release-a 首先,先对排查主机的基本信息有一个了解。Part2运行进程排查首先熟悉一下ps命令的参数:ps[选项] -e显示所有进程。…

    2022年9月15日
    3
  • Cts框架解析(12)-ITargetPreparer

    Cts框架解析(12)-ITargetPreparer

    2022年2月4日
    53
  • DFA算法简单理解实现

    背景:因为最近项目要使用到敏感词过滤服务,在网上了解到dfa实现这个功能性能还不错,特此学习了一下1.什么是DFA算法引用简书作者:浪人与酒丶的解释原文链接:https://www.jianshu.com/p/c67f917c9363DFA全称为:DeterministicFiniteAutomaton,即确定有穷自动机。其特征为:有一个有限状态集合和一些从一个状态通向另一个状态的边,每条边上标记有一个符号,其中一个状态是初态,某些状态是终态。但不同于不确定的有限自动机,DFA中不.

    2022年4月8日
    41
  • 第十八篇 项目范围管理__六个过程[通俗易懂]

    第十八篇 项目范围管理__六个过程[通俗易懂]项目范围管理包括以下过程

    2022年9月22日
    2
  • 数独口诀_数独技巧xwing推导过程

    数独口诀_数独技巧xwing推导过程数独是一种传统益智游戏,你需要把一个 9×9 的数独补充完整,使得图中每行、每列、每个 3×3 的九宫格内数字 1∼9 均恰好出现一次。请编写一个程序填写数独。输入格式输入包含多组测试用例。每个测试用例占一行,包含 81 个字符,代表数独的 81 个格内数据(顺序总体由上到下,同行由左到右)。每个字符都是一个数字(1−9)或一个 .(表示尚未填充)。您可以假设输入中的每个谜题都只有一个解决方案。文件结尾处为包含单词 end 的单行,表示输入结束。输出格式每个测试用例,输出一行数据,代表填充

    2022年8月9日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号