笛卡尔心形函数表达式_笛卡尔情书的秘密——心形函数的绘制

本文来自:http://www.iteye.com/topic/907069

r=a(1-sinθ)

据说这是笛卡尔死前寄出的最后一封情书的内容,

这里面隐藏着一个刻骨铭心的秘密。。。

一生只为等待能手绘这个函数给我的人

借助canvas的arc方法,将此函数绘制如下:

/p>

html>

Cardioid

href='http://www.cssass.com'>cssass.com

提醒您:ie低版本用户请一边惭愧去

吧,ie9可能需刷新。或者你试试访问

href='http://www.wolframalpha.com/input/?i=r%3D100%281-sin%CE%B8%29'>

这个网站

var $id=function(n){

return document.getElementById(n) || n;

}

window.addEventListener("load",draw, false);

var con=$id("pad").getContext('2d');

con.fillStyle='#f00'

con.translate(300,100);

function draw(){

var r=0 , a=100 , start = 0 , end= 0;

con.rotate(Math.PI);

for(var q=0; q<

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是使用笛卡尔心形函数绘制心形图案的示例代码: ```cpp #include <QApplication> #include <QWidget> #include <QPainter> #include <QPen> #include <QBrush> #include <cmath> class Heart : public QWidget { public: Heart(QWidget *parent = 0): QWidget(parent) {} protected: void paintEvent(QPaintEvent *event) override { QPainter painter(this); painter.setRenderHint(QPainter::Antialiasing, true); QPen pen(Qt::red, 2, Qt::SolidLine, Qt::RoundCap, Qt::RoundJoin); painter.setPen(pen); QBrush brush(Qt::red, Qt::SolidPattern); painter.setBrush(brush); painter.translate(width() / 2, height() / 2); QPainterPath path; const double pi = 3.14159265358979323846; const double a = 100; const double b = 100; const int n = 100; const double step = 2 * pi / n; for (double t = 0; t < 2 * pi; t += step) { double x = a * pow(sin(t), 3); double y = b * pow(cos(t), 3); path.lineTo(x, y); } painter.drawPath(path); } }; int main(int argc, char *argv[]) { QApplication app(argc, argv); Heart heart; heart.resize(300, 300); heart.show(); return app.exec(); } ``` 这个示例使用笛卡尔心形函数绘制了一个红色的心形图案,你可以在 paintEvent 函数中看到绘制的具体过程。我们定义了心形函数中的两个参数 a 和 b,以及在一个周期内的点数 n,然后通过循环计算出每个点的坐标,最后使用 QPainterPath 类将这些点连接起来,得到了心形的形状。如果你想要绘制不同大小或颜色的心形,你可以修改对应的参数即可。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值