ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 257|回复: 17

[分享] 用函数曲线在PPT中绘制曲线花

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-12-6 00:01 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
看到其他兄弟在PPT中绘制函数图像,忽然灵光一现,搞了个好玩的功能,通过一些周期性的曲线,在PPT中绘制函数曲线花型,看起来还挺好看的。
可以调整参数,画出各种各样的图形。我的目标是为了做PPT,就看这个玩具功能以后能不能有啥用了。。。


曲线1.gif
曲线2.gif
屏幕截图 2024-12-05 232017.png

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-12-6 12:57 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
不错,程序能否欣赏一下。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-12-6 14:43 | 显示全部楼层
dongdonggege 发表于 2024-12-6 12:57
不错,程序能否欣赏一下。

这个只是插件里面的一个小功能,插件暂时不会发。如果你只是想问问绘制曲线的代码,我可以分享一些,其实就是一个公式而已。这些代码不能直接用,但是可以改改就能用,比如PointD结构的Offset方法,也是我自己写的。
C#代码,返回的PointD序列,将其连起来就是那个曲线了。另外PointD是我自己的定义的一个结构,主要是PointF在进行曲线运算的时候,舍入误差太大了。容易累积。
贝壳形曲线:
  1. public static List<PointD> ShellCurve(PointD origin, double paraA, double paraB)
  2.             {
  3.                 List<PointD> points = [];
  4.                 double delta = Math.PI / 180;
  5.                 for (int i = 0; i < 360; i++)
  6.                 {
  7.                     double t = i * delta;
  8.                     double r = paraA * (paraB + 2 * Math.Cos(t) + Math.Pow(Math.Sin(90 * t), 3));
  9.                     points.Add(new PointD(r * Math.Cos(t), r * Math.Sin(t)).Offset(origin));
  10.                 }
  11.                 points.Add(points.First());
  12.                 return points;
  13.             }
复制代码
盆形曲线:
  1. public static List<PointD> BasinCurve(PointD origin, double paraA, double paraB, int paraN)
  2.             {
  3.                 List<PointD> points = [];
  4.                 int steps = paraN / 2;
  5.                 double dlta = Math.PI / 90 / steps;
  6.                 for (int i = 0; i < 90 * steps; i++)
  7.                 {
  8.                     double t = i * dlta;
  9.                     double x = paraA * Math.Cos(paraN * t - t) * Math.Cos(paraN * t), y = paraB * Math.Pow(Math.Cos(paraN * t), 2);
  10.                     points.Add(new PointD(x, y).Offset(origin));
  11.                 }
  12.                 points.Add(points.First());
  13.                 return points;
  14.             }
复制代码
玫瑰线(里面的GreatestCommonDivisor是一个静态方法,求最大公约数的):
  1. public static List<PointD> RoseCurve(PointD origin, double paraA, int paraN, int paraT)
  2.             {
  3.                 double n = (double)paraN / paraT;
  4.                 int gcd = paraN > paraT ? GreatestCommonDivisor(paraN, paraT) : GreatestCommonDivisor(paraT, paraN);
  5.                 paraN /= gcd; paraT /= gcd;
  6.                 int steps = (paraT / 5 + 1) * 90;
  7.                 double dlta = Math.PI / steps;
  8.                 if (paraN % 2 == 0 || paraT % 2 == 0) paraT *= 2;
  9.                 steps *= paraT;
  10.                 List<PointD> points = [];
  11.                 for (int i = 0; i < steps; i++)
  12.                 {
  13.                     double x = paraA * Math.Sin(n * i * dlta) * Math.Cos(i * dlta), y = paraA * Math.Sin(n * i * dlta) * Math.Sin(i * dlta);
  14.                     points.Add((new PointD(x, y)).Offset(origin));
  15.                 }
  16.                 points.Add(points.First());
  17.                 return points;
  18.             }
复制代码
等等.....
想画曲线可以去网上找找那些曲线的方程,很多的,想在PPT里面画出来好看,最麻烦的就是找闭合周期了。有些算的出来,有些靠试出来的!

TA的精华主题

TA的得分主题

发表于 2024-12-6 15:53 | 显示全部楼层
看不懂,不如不发,这里是VBA论坛,你搞个C#的,没法学。

TA的精华主题

TA的得分主题

发表于 2024-12-6 16:10 | 显示全部楼层
看看是不是这样的?
贝壳形曲线.jpg

贝壳形曲线.zip

19.06 KB, 下载次数: 7

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-12-6 16:57 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-12-6 17:00 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
dongdonggege 发表于 2024-12-6 15:53
看不懂,不如不发,这里是VBA论坛,你搞个C#的,没法学。

我以前搞VBA,现在写VSTO插件,感觉用C# 比VB舒服些。我C#也是搞的时候才学的,说实话,我感觉语言基本都相通。

TA的精华主题

TA的得分主题

发表于 2024-12-6 19:01 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
是不是这个,还欠缺点。C#的pow是绝对值,还是根号?对你的函数表达式不懂。
无标题.jpg

TA的精华主题

TA的得分主题

发表于 2024-12-6 19:18 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
要是函数的3次方,就变成这样的图像。
无标题2.jpg

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-12-7 11:59 | 显示全部楼层
dongdonggege 发表于 2024-12-6 19:01
是不是这个,还欠缺点。C#的pow是绝对值,还是根号?对你的函数表达式不懂。

你只是需要公式的话,我用常规的书写格式给你。C#中Math.Pow是乘方,比如X^2 就是Math.Pow(x,2)

1、玫瑰线
x = A * sin(nθ) *cos(θ) ;  y = A * sin(nθ) * sin(θ)


2、李萨如曲线
x = A * sin(Nθ + C) ; y = B * Sin(Mθ)


3、贝壳曲线
极坐标形式:ρ = A * (B + 2 cos(θ) + sin(90 θ)^3)


4、盆形曲线
x = A * cos(Nθ -θ) * cos(Nθ) ; y = B * cos(Nθ)^2


5、领结形曲线
p = A * sin(Mθ) , q = C * cos(Nθ +C)
x = p * cos (q) ; y = p * sin(q)


6、星形
x = A / q * ((q -1) * cosθ + cos((q-1)θ)) ; y = A / q * ((q -1) * sinθ - sin((q-1)θ))


7、耳蜗形
if θ>0 then s=1 else s=-1
x = s * A * sinθ / sqrt(|θ|) ; y = s * B * (1-cosθ) / sqrt(|θ|)


8、幸运草
极坐标形式:ρ = A * (1 + cos(Nθ) + sin(Nθ)^2)


9、外轮旋线(内轮旋就是将x坐标的cos相减改为相加)
n = R - r , m = (R-r)/r
x = n * cos(θ) - D * cos(mθ) ; y = n * sinθ - D * sin(mθ)


以上,x,y为点坐标,ρ为极径,θ为参数(弧度值),其他均为常数参数,取值不同,影响形状大小。


您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-12-21 13:03 , Processed in 0.039502 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表