在 C# 中绘制希尔伯特曲线分形

这个非常短的Hilbert子程序绘制了 Hilbert 曲线。它以递归深度以及指定绘制方向的 dx和dy值作为参数。它以递归方式绘制了四条较小的 Hilbert 曲线并用线将它们连接起来。

cs 复制代码
// Draw a Hilbert curve.
private void Hilbert(Graphics gr, int depth, float dx, float dy)
{
    if (depth > 1) Hilbert(gr, depth - 1, dy, dx);
    DrawRelative(gr, dx, dy);
    if (depth > 1) Hilbert(gr, depth - 1, dx, dy);
    DrawRelative(gr, dy, dx);
    if (depth > 1) Hilbert(gr, depth - 1, dx, dy);
    DrawRelative(gr, -dx, -dy);
    if (depth > 1) Hilbert(gr, depth - 1, -dy, -dx);

    if (DoRefresh) picCanvas.Refresh();
}

由于 C# 没有提供简单的相对线绘制方法,因此代码中包含了一种方法。DrawRelative函数从点 (LastX, LastY) 绘制一条线到新点,并将该点的坐标存储在变量LastX和LastY中。

cs 复制代码
private float LastX, LastY;
...
// Draw the line (LastX, LastY)-(LastX + dx, LastY + dy) and
// update LastX = LastX + dx, LastY = LastY + dy.
private void DrawRelative(Graphics gr, float dx, float dy)
{
    gr.DrawLine(Pens.Black, LastX, LastY, LastX + dx, LastY + dy);
    LastX = LastX + dx;
    LastY = LastY + dy;
}

勾选程序的"刷新"框,使其在绘制每条线时更新其显示。这会大大减慢程序的速度,但它可以让您看到程序绘制深度大于 4 或 5 的线的顺序。

下载示例

https://download.csdn.net/download/ljygood2/90123675

相关推荐
敲代码的 蜡笔小新3 小时前
【行为型之访问者模式】游戏开发实战——Unity灵活数据操作与跨系统交互的架构秘诀
unity·设计模式·c#·访问者模式
明耀4 小时前
WPF C# 用WebView加载H5页面(uniapp项目,vue项目)
uni-app·c#·wpf
90后小陈老师5 小时前
3D个人简历网站 5.天空、鸟、飞机
前端·javascript·3d
我不是程序猿儿8 小时前
【C#】 lock 关键字
java·开发语言·c#
前端小崔11 小时前
从零开始学习three.js(18):一文详解three.js中的着色器Shader
前端·javascript·学习·3d·webgl·数据可视化·着色器
2301_7869643611 小时前
EXCEL Python 实现绘制柱状线型组合图和树状图(包含数据透视表)
python·microsoft·excel
动感光博12 小时前
Unity序列化字段、单例模式(Singleton Pattern)
unity·单例模式·c#
黑洞视界13 小时前
NCC Mocha v0.2.0 发布, 新增对 Metrics 的支持
c#·.net·可观测性·observability
FAREWELL0007513 小时前
Unity基础学习(十五)核心系统——音效系统
学习·unity·c#·游戏引擎