VBA,Shapes.AddCurve SafeArrayOfPoints:=pts  画贝塞尔曲线

 

1  Shapes.AddCurve SafeArrayOfPoints:=pts   贝塞尔曲线

  • https://docs.microsoft.com/zh-cn/office/vba/api/excel.shapes.addcurve
  • 由指定曲线的顶点和控制点的坐标对组成的数组。 您指定的第一个点是起始顶点, 接下来的两个点是第一段贝塞尔线段的控制点。 该曲线每增加一条线段,就要为其指定一个顶点和两个控制点。您指定的最后一个点是曲线的结束顶点。 请注意,必须指定的点数始终为 3n + 1,其中 n 为曲线的线段个数。
  • SafeArrayOfPoints:=pts 
  • 贝塞尔曲线
  • 起点,2控制点,2控制点 .....终点------好像必须是3n+1,比如4,7,10等等
  • 第2维只能是2?

 

1.1 贝塞尔曲线

https://www.zhihu.com/question/29565629

https://baike.baidu.com/item/%E8%B4%9D%E5%A1%9E%E5%B0%94%E6%9B%B2%E7%BA%BF/1091769?fr=aladdin

它通过控制曲线上的四个点(起始点、终止点以及两个相互分离的中间点)来创造、编辑图形。其中起重要作用的是位于曲线中央的控制线。这条线是虚拟的,中间与贝塞尔曲线交叉,两端是控制端点。移动两端的端点时贝塞尔曲线改变曲线的曲率(弯曲的程度);移动中间点(也就是移动虚拟的控制线)时,贝塞尔曲线在起始点和终止点锁定的情况下做均匀移动。注意,贝塞尔曲线上的所有控制点、节点均可编辑。这种“智能化”的矢量线条为艺术家提供了一种理想的图形编辑与创造的工具。


 

Sub t5()
Dim pts(1 To 4, 1 To 2) As Single
pts(1, 1) = 10
pts(1, 2) = 50

pts(2, 1) = 200
pts(2, 2) = 120

pts(3, 1) = 150
pts(3, 2) = 210

pts(4, 1) = 310
pts(4, 2) = 220

Worksheets("sheet4").Shapes.AddCurve SafeArrayOfPoints:=pts

End Sub

 

1.2 第2个贝塞尔曲线

 

Sub t6()
Dim pts(1 To 10, 1 To 2) As Single
pts(1, 1) = 10         '

pts(1, 2) = 50         '这种分类是错误的
pts(2, 1) = 200

pts(2, 2) = 120
pts(3, 1) = 150

pts(3, 2) = 210
pts(4, 1) = 310

pts(4, 2) = 220
pts(5, 1) = 110

pts(5, 2) = 280
pts(6, 1) = 190

pts(6, 2) = 220
pts(7, 1) = 150

pts(7, 2) = 210
pts(8, 1) = 310

pts(8, 2) = 220
pts(9, 1) = 110

pts(9, 2) = 280
pts(10, 1) = 190

pts(10, 2) = 210


Worksheets("sheet5").Shapes.AddCurve SafeArrayOfPoints:=pts

End Sub

 

1.3 根据这个原理,控制4个点,果然可以画出想要的这种波浪曲线

  • 起点: 和终点在同一个高度
  • 终点:X大,Y=Y起点
  • 控制点1:X前进,Y往上
  • 控制点2:X继续前进,Y往下

 

 

Sub t5()
Dim pts(1 To 4, 1 To 2) As Single
pts(1, 1) = 0           '第1个点的X坐标
pts(1, 2) = 150         '第1个点的Y坐标

pts(2, 1) = 150         '第2个点的X坐标
pts(2, 2) = 0

pts(3, 1) = 200         '第3个点的X坐标
pts(3, 2) = 300

pts(4, 1) = 400
pts(4, 2) = 150

Worksheets("sheet4").Shapes.AddCurve SafeArrayOfPoints:=pts

End Sub
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
这段VBA代码用于在活动工作表上添加一个散点图,并设置散点图的类型、数据源、位置和样式。以下是对代码的解释: ```vba Set chrt = ActiveSheet.Shapes.AddChart().Chart With chrt .ChartType = xlXYScatterSmooth .SetSourceData Source:=[B1] .Parent.Left = rng.Resize(16, 4).Offset(1, 0).Left .Parent.Top = rng.Resize(16, 4).Offset(1, 0).Top .Parent.Height = rng.Resize(16, 4).Offset(1, 0).Height If flag = 0 Then .Parent.Width = rng.Resize(16, 4).Offset(1, 0).Width Else .Parent.Width = rng.Resize(16, 5).Offset(1, 0).Width End If .ChartArea.Interior.Color = RGB(255, 255, 204) End With ``` - `Set chrt = ActiveSheet.Shapes.AddChart().Chart`:这行代码创建一个新的图表对象,并将其赋给变量 `chrt`。 - `.ChartType = xlXYScatterSmooth`:这行代码将图表的类型设置为平滑散点图。 - `.SetSourceData Source:=[B1]`:这行代码将单元格 `B1` 的数据设置为图表的数据源。 - `.Parent.Left = rng.Resize(16, 4).Offset(1, 0).Left` 和 `.Parent.Top = rng.Resize(16, 4).Offset(1, 0).Top`:这些行代码将图表的左侧边缘和顶部边缘设置为范围 `rng` 的右下方偏移一个单元格的位置。 - `.Parent.Height = rng.Resize(16, 4).Offset(1, 0).Height`:这行代码将图表的高度设置为范围 `rng` 的右下方偏移一个单元格的高度。 - `.Parent.Width = rng.Resize(16, 4).Offset(1, 0).Width` 和 `.Parent.Width = rng.Resize(16, 5).Offset(1, 0).Width`:这些行代码将图表的宽度设置为范围 `rng` 的右下方偏移一个单元格的宽度。根据变量 `flag` 的值,决定是使用4列还是5列的宽度。 - `.ChartArea.Interior.Color = RGB(255, 255, 204)`:这行代码将图表区域的背景颜色设置为 RGB(255, 255, 204),即浅黄色。 整体上,这段代码创建了一个散点图,并对其进行了一系列设置,包括类型、数据源、位置和样式。希望对您有所帮助。如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值