在 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

相关推荐
浩浩测试一下43 分钟前
内网---> WriteOwner权限滥用
网络·汇编·windows·安全·microsoft·系统安全
铁蛋AI编程实战1 小时前
MemoryLake 实战:构建超长对话 AI 助手的完整代码教程
人工智能·python·microsoft·机器学习
心疼你的一切2 小时前
三维创世:CANN加速的实时3D内容生成
数据仓库·深度学习·3d·aigc·cann
3DVisionary10 小时前
掌控发动机“心脏”精度:蓝光3D扫描在凸轮轴全尺寸检测中的应用
3d·图形渲染·汽车发动机·精密测量·蓝光3d扫描·凸轮轴检测·形位公差
.房东的猫11 小时前
ERP(金蝶云星空)开发【安装篇】
c#
山岚的运维笔记17 小时前
SQL Server笔记 -- 第14章:CASE语句
数据库·笔记·sql·microsoft·sqlserver
coder攻城狮17 小时前
VTK系列1:在屏幕绘制多边形
c++·3d
Sharewinfo_BJ18 小时前
PowerBI 2026年1月功能更新|效率升级,体验再优化
windows·microsoft·powerbi
PHOSKEY19 小时前
3D工业相机如何“读透”每一个字符?快速识别、高精度3D测量
数码相机·3d
fie888919 小时前
基于C#的推箱子小游戏实现
开发语言·c#