我试图System.Windows.Forms.Form
在 F# 中绘制一个非自定义的(我的意思是,只是创建默认表单类的实例,而不是我可以创建的派生类的实例)。
我创建了一个自定义表单,但我不需要也不想要这样一个新的复杂结构,所以我删除了它,它大大简化了代码;如此之多,以至于它停下来显示图像。
问题一定出在我创建的要绘制的函数中,也就是在另一个 F# 项目中。我已经创建它(函数)以按照提供的顺序conect
连接点,不像,它以其他顺序在点之间绘制线,为什么还没有注意到(可能从右到左,从上到下,因为点是代表)。System.Drawing.Graphics.DrawLines
Programa.fs 相关代码片段:
let pen = new Pen(brush = Brushes.Black, width = 1.0f)
let original =
([|new PointF(50.0f, 50.0f); new PointF(100.0f, 50.0f)|])
use form1 = new Form(Width = 400, Height = 400, Text = "Fractais (Teste - Windows Forms)")
form1.Paint.Add(
fun e -> // (1)
original
|> List.ofArray
|> Base.applyFractal 1uy Base.fractalFunc1
|> Base.conect e.Graphics pen)
如果在 lambda 表达式中而不是写的有e.Graphics.DrawLines(pen, original)
,它将在列表中的点之间画一条简单的线。
这是 Base.fs 中解决方案中的麻烦制造者方法:
let conect (gr:Graphics) (pen:Pen) (points:PointF list) =
let rec usefulFunc (gr:Graphics) (pen:Pen) (points:PointF list) prevPoint =
match points with
| [] -> ()
| point :: remainings ->
gr.DrawLine (pen, prevPoint, point)
usefulFunc gr caneta remainings.Tail remainings.Head
usefulFunc gr pen points.Tail points.Head
以及 Base.fsi 中的调用(来自表单初始化片段)和相关方法的签名(我可以为您提供所有完整方法的实现,但这会占用大量空间,这可能适合您已经成为一个很长的问题要阅读):
val fractalFunc1 : points:PointF list -> PointF list
val applyFractal : stepNumber:byte -> fractalFunc:(PointF list -> PointF list) -> points:PointF list -> PointF list
val conect : gr:Graphics -> pen:Pen -> points:PointF list -> unit
对于这个特定的问题,我的搜索结果没有。我想知道如何使该功能conect
正常工作。
提前致谢。