3

我试图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正常工作。

提前致谢。

4

1 回答 1

5

您在 conectar 中有一个错误。

fUtil gr caneta resto.Tail resto.Head

应该

fUtil gr caneta resto ponto

您已经在 match 语句中匹配了头部和尾部。

下面的代码为我画了一条线。我不必修改太多。

open System.Drawing
open System.Windows.Forms

let caneta = new Pen(brush = Brushes.Black, width = 1.0f)
let original =            
    ([|new PointF(50.0f, 50.0f); new PointF(100.0f, 50.0f)|])

let form1 = new Form(Width = 400, Height = 400, Text = "Fractais (Teste - Windows Forms)")

let conectar (gr:Graphics) (caneta:Pen) (pontos:PointF list) =
    let rec fUtil (gr:Graphics) (caneta:Pen) (pontos:PointF list) pontoAnt =
        match pontos with
        | [] -> ()
        | ponto :: resto ->                
            gr.DrawLine (caneta, pontoAnt, ponto)
            fUtil gr caneta resto ponto
    fUtil gr caneta pontos.Tail pontos.Head

form1.Paint.Add(
    fun e -> // (1)
        original
        |> List.ofArray        
        //|> aplicFractal 1uy Base.funcFractal1
        |> conectar e.Graphics caneta)

form1.Show()

Application.Run(form1)
于 2013-03-06T18:34:19.770 回答