java---实现3D山脉模型

2024-03-03 03:59
文章标签 java 实现 模型 3d 山脉

本文主要是介绍java---实现3D山脉模型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

核心理念:递归

其实3D山脉基本思路可以认为是平面山脉和谢冰斯基三角形的结合体,敲代码之前请大家先了解一个取中点时第一个技巧,即取两个点中点时需要让中点的横坐标或纵坐标或同时减或加上一个极小的随机值,来产生山脉连绵起伏的效果,我通过查阅相关资料发现有些人将其称为中值震荡点,咱们就暂且这么称呼它吧

初步思路:

1.图中随机选取三个点

2.然后取中值震荡点

3.连接相应的顶点和中值震荡点

4.然后不断迭代,迭代到一定次数结束迭代

代码如下

public void recur3D(Graphics g, double x1,  double y1,double x2, double y2,double x3,double y3, int range) {                                                if (range==0) {int[] px = { (int)x1, (int)x2, (int)x3 };int[] py = { (int)y1, (int)y2, (int)y3 };g.drawPolygon(px, py, 3);return;}else {Random rand=new Random();int num=rand.nextInt(range*2)-range;double ax,ay,bx,by,cx,cy;ax = (x1 + x2) / 2 ;ay = (y1 + y2) / 2 + num;bx = (x1 + x3) / 2;by = (y1 + y3) / 2 + num;cx = (x2 + x3) / 2;cy = (y2 + y3) / 2 + num;//以上全部都是在y轴上取震荡点,造成起伏效果,其实也可以在x轴上震荡range*=0.55;recur3D(g, x1, y1, ax, ay, bx, by, range);recur3D(g, x2, y2, ax, ay, cx, cy, range);recur3D(g, x3, y3, cx, cy, bx, by, range);recur3D(g, ax, ay, cx, cy, bx, by, range);}}

效果图

 结果我发现山脉上出现了许多的裂缝,其实这不难理解在取中值震荡点时可能取到同一个点,从而造成割裂,解决方案的话就是使用一个数组储存中值震荡点,如果取到过就直接使用,如果未储存就求取中值震荡点

代码如下

public void recur3D(Graphics g, double x1,  double y1,double x2, double y2,double x3,double y3, int range) {//我用的range为100if (range==0) {int[] px = { (int)x1, (int)x2, (int)x3 };int[] py = { (int)y1, (int)y2, (int)y3 };		g.drawPolygon(px, py, 3);return;}else {Random rand=new Random();int num=rand.nextInt(range*2)-range;double ax,ay,bx,by,cx,cy;int u=0,j=0,o=0;boolean f1=true;boolean f2=true;boolean f3=true;for(int i=0;i<counts;i++) {if((x1 == po[i].x1&&x2==po[i].x2&&y1==po[i].y1&&y2==po[i].y2)||(x1==po[i].x2&&x2==po[i].x1&&y1==po[i].y2&&y2==po[i].y1)){f1=false;u=i;break;}}for(int i=0;i<counts;i++) {if((x2 == po[i].x1&&x3==po[i].x2&&y2==po[i].y1&&y3==po[i].y2)||(x2==po[i].x2&&x3==po[i].x1&&y2==po[i].y2&&y3==po[i].y1)){f2=false;j=i;break;}}for(int i=0;i<counts;i++) {if((x1 == po[i].x1&&x3==po[i].x2&&y1==po[i].y1&&y3==po[i].y2)||(x1==po[i].x2&&x3==po[i].x1&&y1==po[i].y2&&y3==po[i].y1)){f3=false;o=i;break;}}if(!f1) {ax=po[u].X;ay=po[u].Y;} else {ax = (x1 + x2) / 2 ;ay = (y1 + y2) / 2 + num;Point p=new Point(x1,x2,y1,y2,ax,ay);counts++;po[counts-1]=p;}if(!f3) {bx=po[o].X;by=po[o].Y;} else {bx = (x1 + x3) / 2;by = (y1 + y3) / 2 + num;Point p=new Point(x1,x3,y1,y3,bx,by);counts++;po[counts-1]=p;}if(!f2) {cx=po[j].X;cy=po[j].Y;} else {cx = (x2 + x3) / 2;cy = (y2 + y3) / 2 + num;Point p=new Point(x2,x3,y2,y3,cx,cy);counts++;po[counts-1]=p;}range*=0.55;recur3D(g, x1, y1, ax, ay, bx, by, range);recur3D(g, x2, y2, ax, ay, cx, cy, range);recur3D(g, x3, y3, cx, cy, bx, by, range);recur3D(g, ax, ay, cx, cy, bx, by, range);}}

效果如下

 其实还可以添加颜色来使其更美观,如

			g.setColor(new Color(0,140,0,new Random().nextInt(40)));

大功告成,感谢观众老爷们阅读 ≧◇≦,如有错误,敬请指正

这篇关于java---实现3D山脉模型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/768383

相关文章

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

python中列表list切分的实现

《python中列表list切分的实现》列表是Python中最常用的数据结构之一,经常需要对列表进行切分操作,本文主要介绍了python中列表list切分的实现,文中通过示例代码介绍的非常详细,对大家... 目录一、列表切片的基本用法1.1 基本切片操作1.2 切片的负索引1.3 切片的省略二、列表切分的高

基于Python实现一个PDF特殊字体提取工具

《基于Python实现一个PDF特殊字体提取工具》在PDF文档处理场景中,我们常常需要针对特定格式的文本内容进行提取分析,本文介绍的PDF特殊字体提取器是一款基于Python开发的桌面应用程序感兴趣的... 目录一、应用背景与功能概述二、技术架构与核心组件2.1 技术选型2.2 系统架构三、核心功能实现解析

使用Java发送邮件到QQ邮箱的完整指南

《使用Java发送邮件到QQ邮箱的完整指南》在现代软件开发中,邮件发送功能是一个常见的需求,无论是用户注册验证、密码重置,还是系统通知,邮件都是一种重要的通信方式,本文将详细介绍如何使用Java编写程... 目录引言1. 准备工作1.1 获取QQ邮箱的SMTP授权码1.2 添加JavaMail依赖2. 实现

Java嵌套for循环优化方案分享

《Java嵌套for循环优化方案分享》介绍了Java中嵌套for循环的优化方法,包括减少循环次数、合并循环、使用更高效的数据结构、并行处理、预处理和缓存、算法优化、尽量减少对象创建以及本地变量优化,通... 目录Java 嵌套 for 循环优化方案1. 减少循环次数2. 合并循环3. 使用更高效的数据结构4

使用Python实现表格字段智能去重

《使用Python实现表格字段智能去重》在数据分析和处理过程中,数据清洗是一个至关重要的步骤,其中字段去重是一个常见且关键的任务,下面我们看看如何使用Python进行表格字段智能去重吧... 目录一、引言二、数据重复问题的常见场景与影响三、python在数据清洗中的优势四、基于Python的表格字段智能去重

java两个List的交集,并集方式

《java两个List的交集,并集方式》文章主要介绍了Java中两个List的交集和并集的处理方法,推荐使用Apache的CollectionUtils工具类,因为它简单且不会改变原有集合,同时,文章... 目录Java两个List的交集,并集方法一方法二方法三总结java两个List的交集,并集方法一

Spring AI集成DeepSeek三步搞定Java智能应用的详细过程

《SpringAI集成DeepSeek三步搞定Java智能应用的详细过程》本文介绍了如何使用SpringAI集成DeepSeek,一个国内顶尖的多模态大模型,SpringAI提供了一套统一的接口,简... 目录DeepSeek 介绍Spring AI 是什么?Spring AI 的主要功能包括1、环境准备2

Spring AI集成DeepSeek实现流式输出的操作方法

《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav