分形之正方形折线

 这种分形图形是将一条线段拆分成五条线段,其中第一条线段使用原线段的前三分之一,最后一条线段使用原线段的后三分之一。中间三条线段围成一个开口的正方形。

核心代码:

复制代码
static void FractalSquare(const Vector3& vStart, const Vector3& vEnd, Vector3* pVertices)
{
    Vector3 vSub = vEnd - vStart;
    Yreal len = D3DXVec3Length(&vSub);

    pVertices[0] = vStart;
    pVertices[5] = vEnd;

    Vector3 vMiddle;
    vMiddle.x = (vStart.x + vStart.y + vEnd.x - vEnd.y) / 2;
    vMiddle.y = (vEnd.x + vEnd.y + vStart.y - vStart.x) / 2;
    vMiddle.z = 0.0f;

    pVertices[1] = vStart + vSub/3.0f;
    pVertices[4] = vStart + vSub/1.5f;

    pVertices[2] = (vStart + vMiddle*2.0f)/3.0f;
    pVertices[3] = (vEnd + vMiddle*2.0f)/3.0f;
}
复制代码

软件截图:

分形之正方形折线_第1张图片

分形之正方形折线_第2张图片

分形之正方形折线_第3张图片

分形之正方形折线_第4张图片

分形之正方形折线_第5张图片

分形之正方形折线_第6张图片

分形之正方形折线_第7张图片

软件下载地址:http://files.cnblogs.com/WhyEngine/Fractal.7z

你可能感兴趣的:(分形之正方形折线)