gpt4 book ai didi

winforms - 在 F# 中绘制 Windows 窗体

转载 作者:行者123 更新时间:2023-12-01 11:46:02 27 4
gpt4 key购买 nike

我试图绘制一个非自定义的(我的意思是,只是创建默认表单类的实例,而不是我可以创建的派生类的实例)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 工作。

提前致谢。

最佳答案

您在连接中有一个错误。

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)

关于winforms - 在 F# 中绘制 Windows 窗体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15253829/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com