科赫曲线是一种分形。其形态似雪花,又称科赫雪花、雪花曲线.瑞典人科赫于1904年提出了著名的“雪花”曲线,这种曲线的作法是,从一个正三角形开始,把每条边分成三等份,然后以各边的中间长度为底边。分别向外作正三角形,再把“底边”线段抹掉,这样就得到一个六角形,它共有12条边。再把每条边三等份,以各中间部分的长度为底边,向外作正三角形后,抹掉底边线段。反复进行这一过程,就会得到一个“雪花”样子的曲线。这曲线叫做科赫曲线或雪花曲线。

给定线段AB,科赫曲线可以由以下步骤生成:
      (1)将线段分成三等份(AC,CD,DB)
      (2)以CD为底,向外(内外随意)画一个等边三角形DMC
      (3)将线段CD移去
      (4)分别对AC,CM,MD,DB重复1~3。
      反复进行这一作图过程,得到的曲线越来越精细。

  科赫曲线有着极不寻常的特性,不但它的周长为无限大,而且曲线上任两点之间的距离也是无限大。该曲线长度无限,却包围着有限的面积。很神奇的一个曲线,他说明了一个悖论:“无限长度包围着有限面积。”

程序中实现了0~8级的科赫雪花分形.程序设计时,将这9级曲线的顶点数据全部放置在一个内存中.并使用如下结构体进行设置:

    struct SnowLevel
{
Yuint vertexStart;
Yuint verticesCount;
};
SnowLevel m_snowLevels[SNOW_LEVELS_COUNT];
Yuint m_currentLevel;

分形图形的顶点生成算法代码如下:

static void Zhe(const Vector3& vStart, const Vector3& vEnd, Vector3* pVertices)
{
Vector3 vSub = vEnd - vStart; pVertices[] = vStart;
pVertices[] = vStart + vSub/;
pVertices[] = vStart + vSub*/;
pVertices[] = vEnd; Yreal alfa = atan2f(vSub.y, vSub.x);
alfa += YD_REAL_PI/; Yreal l = D3DXVec3Length(&vSub)/;
pVertices[].x = pVertices[].x + cosf(alfa)*l;
pVertices[].y = pVertices[].y + sinf(alfa)*l;
pVertices[].z = 0.0f;
} void CFractalSnowEntity::Fractal(Vector3* pVertices)
{
pVertices[].x = 0.0f;
pVertices[].y = YD_SNOW_RADIUS;
pVertices[].z = 0.0f; pVertices[].x = YD_SNOW_RADIUS*sinf(YD_REAL_PI/);
pVertices[].y = -YD_SNOW_RADIUS*sinf(YD_REAL_PI/);
pVertices[].z = 0.0f; pVertices[].x = -pVertices[].x;
pVertices[].y = pVertices[].y;
pVertices[].z = 0.0f; for (Yuint i = ; i < SNOW_LEVELS_COUNT; i++)
{
const Vector3* pSrc = pVertices + m_snowLevels[i - ].vertexStart;
Vector3* pDest = pVertices + m_snowLevels[i].vertexStart; Yuint c = m_snowLevels[i - ].verticesCount; for (Yuint j = ; j < c; j++)
{
Zhe(pSrc[j], pSrc[(j + )%c], pDest);
pDest += ;
}
}
}

下载地址:http://files.cnblogs.com/WhyEngine/FractalSnow.7z

科赫雪花第0级

科赫雪花第1级

科赫雪花第2级

科赫雪花第3级

科赫雪花第4级

科赫雪花第5级

科赫雪花第6级

科赫雪花第7级

科赫雪花第8级

软件使用说明
键盘0~8,分别设置第0级到第8级分形.
这是个3D程序,鼠标右键的拖动可以改变视角.
键盘X用于恢复为默认视角.
键盘F11用于全屏切换.

分形之科赫(Koch)雪花的更多相关文章

  1. python画图——雪花(科赫曲线)

    科赫曲线是一种分形,其形态非常像雪花,因此又被称作科赫雪花.雪花曲线. 下面是用python的turtle包让我们来实时画一个 import turtledef koch(t,n): #定义一个函数 ...

  2. 科赫曲线和科赫雪花的绘制Python

    #KochDrawV1.pyimport turtledef koch(size,n): if n == 0: turtle.fd(size) else: for angle in [0,60,-12 ...

  3. python: 递归函数(科赫雪花)

    import turtle as t def kehe(size,n): #递归函数 if n==0: t.fd(size) #阶数为0时,为一直线 else: for i in [0,60,-120 ...

  4. 海岸线、科赫曲线、turtle、递归

    本章绘图要点: turtle模块:python标准库自带的一个模块,可用来绘制二维图形.该模块封装了底层的数据处理逻辑,向外提供了更符合手工绘图习惯的接口函数,适用于绘制对质量.精度要求不高的图形. ...

  5. koch曲线与koch雪花的MATLAB实现

    代码 % -- function koch(Ax, Ay, Bx, By) % 控制递归深度 Deepth = ; % 控制图画大小 Size = ; + (By-Ay)^) < Deepth ...

  6. 科赫雪花利用python海龟绘图代码

    #KochDraw.py import turtle //海龟绘图 def koch(size, n): if n == 0: turtle.fd(size) else: for angle in [ ...

  7. pyinstaller库的简单使用 打包科赫雪花几何图形

    pyinstaller 简单使用 (cmd命令行) pyinstaller -F <文件名.py> Pyinstaller库常用参数 参数 描述 -h 查看帮助 --clean 清理打包过 ...

  8. 分形之拆分三角形(Split Triangle)

    前面讲了谢尔宾斯基三角形,它是不停地将一个三角形拆分三个与之相似的三角形.这一节给大家展示的图形是将一个等腰钝角三角形不停地拆分两个与之相似的三角形. 核心代码: static void SplitT ...

  9. 18个分形图形的GIF动画演示

    这里提供18个几何线段分形的GIF动画图像.图形颜色是白色,背景色为黑色,使用最基本的黑与白以表现分形图形. (1)科赫(Koch)雪花   (2)列维(levy)曲线   (3)龙形曲线(Drago ...

随机推荐

  1. Spring 系列教程之容器的功能

    Spring 系列教程之容器的功能 经过前面几章的分析,相信大家已经对 Spring 中的容器功能有了简单的了解,在前面的章节中我们一直以 BeanFacotry 接口以及它的默认实现类 XmlBea ...

  2. idea单元测试左侧装订线中的颜色指示器设置

    又是idea,idea确实很智能,由于我下载的idea设置可能初始化了,所以我找不到单元测试率覆盖的具体代码情况,到底哪些代码覆盖,哪些代码未覆盖:

  3. 数据库MySQL 之 索引原理与慢查询优化

    数据库MySQL 之 索引原理与慢查询优化 浏览目录 索引介绍方法类型 聚合索引辅助索引 测试索引 正确使用索引 组合索引 注意事项 查询计划 慢查询日志 大数据量分页优化 一.索引介绍方法类型 1. ...

  4. Python : locals and globals

    Python有两个内置的函数,locals() 和globals(),它们提供了基于字典的访问局部和全局变量的方式.Python使用叫做名字空间的东西来记录变量的轨迹.名字空间只是一个 字典,它的键字 ...

  5. AOP 环绕通知 (Schema-base方式) 和 AspectJ方式在通知中获取切点的参数

    环绕通知(Schema- base方式) 1.把前置通知和后置通知都写到一个通知中,组成了环绕通知 2.实现步骤: 2.1 新建一个类实现 MethodInterceptor 接口 public cl ...

  6. Graphviz 环境变量设置

    今天晚上解决了一个错误,如下:

  7. 2019.01.10 bzoj1095: [ZJOI2007]Hide 捉迷藏(动态点分治)

    传送门 蒟蒻真正意义上做的第一道动态点分治! 题意:给一棵最开始所有点都是黑点的树,支持把点的颜色变成从黑/白色变成白/黑色,问当前状态树上两个最远黑点的距离. 思路: 首先考虑不带修改一次点分治怎么 ...

  8. 2018.01.04 bzoj5291: [Bjoi2018]链上二次求和(线段树)

    传送门 线段树基础题. 题意:给出一个序列,要求支持区间加,查询序列中所有满足区间长度在[L,R][L,R][L,R]之间的区间的权值之和(区间的权值即区间内所有数的和). 想题555分钟,写题202 ...

  9. 2018.11.08 NOIP模拟 景点(倍增+矩阵快速幂优化dp)

    传送门 首先按照题意构造出转移矩阵. 然后可以矩阵快速幂求出答案. 但是直接做是O(n3qlogm)O(n^3qlogm)O(n3qlogm)的会TTT掉. 观察要求的东西发现我们只关系一行的答案. ...

  10. 2018.06.26 NOIP模拟 纪念碑(线段树+扫描线)

    题解: 题目背景 SOURCE:NOIP2015−GDZSJNZXSOURCE:NOIP2015-GDZSJNZXSOURCE:NOIP2015−GDZSJNZX(难) 题目描述 2034203420 ...