最近在做一个正六边形的游戏,被一开始的布局难倒了。

需求:中心有个正六边形,输入围绕中心扩散的环数,自动创建和摆放。

大概就是这样的吧,我觉得这个非常轻松的就可以搞定了。啊~~~~~啊~~~ 五环~~,你比四环多一环,啊~~~~啊~~~五环~~,你比六环少一环~~~

可是,到底每环要放多少个六边形?经过我缜密的观察发现一个规律。

如果假设第一个环编号为1,那么每个换六边形的数量就是 环数*6。啊~~~~~啊~~~ 五环~~,一环就是紫~禁~城~~~~。

可是摆放的具体位置是哪里?既然是圆形,那就需要知道 角度半径 就可以依据圆形坐标公式算出来了。

二维圆上的点坐标公式:

X = Mathf.Sin(角度*Mathf.PI/180) * 半径

Y = Mathf.Cos(角度*Mathf.PI/180) * 半径

有人可能问,上面写的公式原理是啥?哈~哈~哈~~~~

啊~~~~~啊~~~ 五环~~,你比四环多一环,啊~~~~啊~~~五环~~~~~~

参见:已知圆心,半径,角度,求圆上的点坐标 - - 博客频道 - CSDN.NET

-----半径是啥?

紧密摆放的话,半径就是六边形的宽度。而每一环的半径就是环数*第一个半径。

好了这个可以大概构建一个循环体了。

=========下面搭建循环体============

 Int RoundMax = ;//最大环数变量

 float Radius = 1f;//六边形最短宽度

 for(int round = ;round<=RoundMax;round++)//每一层环的循环体

 {

 for(环上每个六边形循环体)

 Vector2 = new Vector2(Mathf.Sin(角度*Mathf.PI/) * Radius * round, Mathf.Cos(角度*Mathf.PI/) * Radius * round);

 }

 }

===============

那么角度又是多少?

360 ÷ 每一环的总数 = 间隔的角度

间隔的角度 × 当前序号 = 当前角度

=========下面添加每一环的计算程序============

 Int RoundMax = ;//最大环数变量

 float Radius = 1f;//六边形最短宽度

 for(int round = ;round<=RoundMax;round++)//每一层环的循环体

 {

 for(int id = ; id<=round*; id++)//当前环的总个数 = round*6

 {

 Vector2 Pos= new Vector2(

 Mathf.Sin(/(round*)*id*Mathf.PI/) * Radius * round,

 Mathf.Cos(/(round*)*id*Mathf.PI/) * Radius * round

 );

 }

 }

=======下面转为三维向量========

 Int RoundMax = ;//最大环数变量

 float Radius = 1f;//六边形最短宽度

 for(int round = ;round<=RoundMax;round++)//每一层环的循环体

 {

 for(int id = ; id<=round*; id++)//当前环的总个数 = round*6

 {

 Vector3 Pos= new Vector3(

 Mathf.Sin(/(round*)*id*Mathf.PI/) * Radius * round,

 ,

 Mathf.Cos(/(round*)*id*Mathf.PI/) * Radius * round

 );

 }

 }

=====距离胜利还有一步 下面引入模型和创建========

 GameObject Zero_OBJ;//六边形物体

 Int RoundMax = ;//最大环数变量

 float Radius = 1f;//六边形最短宽度

 for(int round = ;round<=RoundMax;round++)//每一层环的循环体

 {

 for(int id = ; id<=round*; id++)//当前环的总个数 = round*6

 {

 Vector3 Pos= new Vector3(

 Mathf.Sin(/(round*)*id*Mathf.PI/) * Radius * round + ,

 ,

 Mathf.Cos(/(round*)*id*Mathf.PI/) * Radius * round

 );

 Instantiate(Zero_OBJ,

 Zero_OBJ.transform.position.+ Pos ,//依据物体坐标偏移

 Quaternion.identity);

 }

 }

=======哈哈哈 我是在佩服我的智慧========

天空飘来五个字 那都不是事

运行结果

我去~~~真圆~~~~~

接下的十几分钟...

=================然后开始奋发图强的思考=============

其实还是有几个摆放正确的六边形

也就是说除了这0 , 60,120 , 180 , 240 , 300 角度的六边形,其余六边形其实不是正圆分布,而是直线分布。

如果是直线分布,就需要依据两点的坐标计算出排列的矢量方向,然后依据半径摆放就可以了。

=====接下吧正确位置写入 Pos_6[]========

 GameObject Zero_OBJ;//六边形物体

 Int RoundMax = ;//最大环数变量

 float Radius = 1f;//六边形最短宽度

 for(int round = ;round<=RoundMax;round++)//每一层环的循环体

 {

 int [] Pos_6 = new int[];//记录正确6个位置的数组

 for(int id = ; id<= ; id++)//当前环的总个数 = round*6

 {

 Vector3 Pos_6[i]= new Vector3(

 Mathf.Sin(/(round*)*id*Mathf.PI/) * Radius * round + ,

 ,

 Mathf.Cos(/(round*)*id*Mathf.PI/) * Radius * round

 );

 Instantiate(Zero_OBJ,

 Zero_OBJ.transform.position.+ Pos_6[i] ,//依据物体坐标偏移

 Quaternion.identity);

 }

 }

中间的六边形个数规律是:

每个六边形偏移距离是:

=======接下来插入之间的六边形========

 GameObject Zero_OBJ;//六边形物体

 Int RoundMax = ;//最大环数变量

 float Radius = 1f;//六边形最短宽度

 for(int round = ;round<=RoundMax;round++)//每一层环的循环体

 {

 int [] Pos_6 = new int[];//记录正确6个位置的数组

 for(int id = ; id<= ; id++)

 {

 Vector3 Pos_6[i]= new Vector3(

 Mathf.Sin(/(round*)*id*Mathf.PI/) * Radius * round + ,

 ,

 Mathf.Cos(/(round*)*id*Mathf.PI/) * Radius * round

 );

 Instantiate(Zero_OBJ,

 Zero_OBJ.transform.position+ Pos_6[i] ,//依据物体坐标偏移

 Quaternion.identity);

 }

 if(round >)//第2圈开始执行插入

 {

 for(int id = ; id<= ; id++)//逐个区间插入

 {

 int NextID =( id+)%;//获取下一个位置ID,在0~5中循环取值

 Vector3 Orientation = Vector3.Normalize(Pos_6[id],Pos_6[NextID])//单位朝向(当前点,上一个点)

 for(int add = ;add<round-;add++)//循环插入

 {

 //----------插入点 = 单位方向*当前偏移距离+起点偏移

 Vector3 Now_Pos =

 Orientation

 *(Radius * add)

 +( Pos_6[id] + Zero_OBJ.transform.position);

 //-------------------------------------------------------------

 Instantiate(Zero_OBJ,Now_Pos,Quaternion.identity);

 }

 }

 }

 }

========运行结果===========

 
作者:CRomputer-罗军
链接:https://zhuanlan.zhihu.com/p/25243438
来源:知乎

Unity3D 正六边形,环状扩散,紧密分布,的程序的更多相关文章

  1. 正六边形网格化(Hexagonal Grids)原理与实现

    在路径规划.游戏设计栅格法应用中,正六边形网格不如矩形网格直接和常见,但是正六边形具有自身的应用特点,更适用于一些特殊场景中,比如旷阔的海洋.区域或者太空.本文主要讲述如何对正六边形进行几何学分析.网 ...

  2. css3--布局正六边形

    怎样布局正六边形?-->如果不能直接布局,就只能采用图形的组合.-->既然是正六边形,则: -->AB=2分之根号3乘2倍的边长,也就是对于矩形ABCD来说,AB是BD的根号3倍(也 ...

  3. ArcGIS中实现指定面积蜂窝(正六边形)方法

    本篇博文为博主(whgiser)原创,转载请注明. 空间聚集研究中,地理尺度大多数都是基于格网构建的,只需fishnet下就行了.也常有使用社区.交通小区(TZ)作为研究单元的.直到发现蜂窝网络做出的 ...

  4. #使用Python的turtle绘制正六边形、叠边形

    1.#Python的turtle绘制正六边形 代码: len=100 #表示边长像素 import turtle as t #正六边形内角都是120度,外角60度 for i in range(6): ...

  5. 内存模型 Memory model 内存分布及程序运行中(BSS段、数据段、代码段、堆栈

    C语言中内存分布及程序运行中(BSS段.数据段.代码段.堆栈) - 秦宝艳的个人页面 - 开源中国 https://my.oschina.net/pollybl1255/blog/140323 Mem ...

  6. 估计量|估计值|置信度|置信水平|非正态的小样本|t分布|大样本抽样分布|总体方差|

    5 估计量和估计值是什么? 估计量不是估计出来的量,是用于估计的量. 估计量:用于估计总体参数的随机变量,一般为样本统计量.如样本均值.样本比例.样本方差等.例如:样本均值就是总体均值的一个估计量. ...

  7. 第五课 Css3旋转放大属性,正六边形的绘制

    ---恢复内容开始--- 一.效果 二.知识点 1.background-color: rgba(0,0,0,.4);   (红色.绿色.蓝色.透明度(0-1)) 2.position: absolu ...

  8. unity3d俄罗斯方块源码教程+源码和程序下载

    小时候,大家都应玩过或听说过<俄罗斯方块>,它是红白机,掌机等一些电子设备中最常见的一款游戏.而随着时代的发展,信息的进步,游戏画面从简单的黑白方块到彩色方块,游戏的玩法机制从最简单的消方 ...

  9. C语言中内存分布及程序运行中(BSS段、数据段、代码段、堆栈)

      BSS段:(bss segment)通常是指用来存放程序中未初始化的全局变量的一块内存区域.BSS是英文Block Started by Symbol的简称.BSS段属于静态内存分配. 数据段 : ...

随机推荐

  1. Java I/O之NIO概念理解

    JDK1.4的java.nio.*包引入了新的Java I/O新类库,其目的在于提高速度.实际上,旧的I/O包已经使用nio重新实现过,以便充分利用这种速度提高,因此即使我们不显式地用nio编码,也能 ...

  2. vs2017 .net core WebApp 去掉ApplicationInsights

    vs2017新建的 .net core WebApp都内置了这个遥测中间件进去,嗯,用AZURE的话是不错能无缝支持.但不用AZURE就没什么用了. 为了不占地方和提高一点点初始启动的速度,对新建的项 ...

  3. iOS集成友盟推送

    之前有写过利用Python自己写一个推送服务器, 今天说下如果集成友盟的推送服务 在这之前我们需要做一些准备动作 #1. 注册一个App ID #2. Enable Push Notification ...

  4. Springs Element 'beans' cannot have character [children], because the type's content type is element-only

    Springs Element 'beans' cannot have character [children], because the type's content type is element ...

  5. ACM 组合数

    组合数 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 找出从自然数1.2.... .n(0<n<10)中任取r(0<r<=n)个数的所有组合 ...

  6. 算法模板——splay区间反转 1

    实现的功能:将序列区间反转,并维护 详见BZOJ3223 var i,j,k,l,m,n,head,a1,a2:longint; s1:ansistring; a,b,c,d,fat,lef,rig: ...

  7. Android在未来对 Java 8 特性的支持

    在谷歌, 我们总是努力做正确的事. 这意味着有时候我们会调整自己的计划. 我们深切地知道开发者社区是多少地关注 Android 能够对 Java 8 良好的支持, 并且我们正在改变自己对 Java 8 ...

  8. 来谈一谈------JavaScript对象

    1.window常用的属性: ①history ②location 2.history对象的方法: ①back() ②forward() ③go() 3.location对象的属性: ①host() ...

  9. Cordova原理一

    我们知道cordova中js要和native通信都是通过 cordova plugin来实现的.如果我们自己创建一个cordova plugin,它其实就是几个独立的文件按照一定的目录结构放在一起,然 ...

  10. MIT 计算机科学及编程导论 Python 笔记 1

    计算机科学及编程导论在 MIT 的课程编号是 6.00.1,是计算机科学及工程学院的经典课程.之前,课程一直使用 Scheme 作为教学语言,不过由于 Python 简单.易学等原因,近年来已经改用 ...