php情书之笛卡尔的情书,笛卡尔情书的秘密——心形函数的作图

笛卡尔情书的秘密——心形函数的绘制

本文来自: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<500; q++){

start += Math.PI * 2 /500;

end = start + Math.PI * 2 /500;

r=a * (1-Math.sin(start)); //心形极坐标表示法

con.arc(0,0,r,start,end,false);

}

con.fill();

}

如果使用bezierCurveTo方法,绘制各种曲线图形也不在话下,但那并不是通过心形函数本身绘制的。

关于心形线的一些资料

话说,极坐标公式是非常利于绘制图形的。

比如玫瑰线公式:r(θ) = a sin kθ

阿基米德螺线公式:r(θ) = a+bθ

都可以绘制如下:

/p>

html>

Rose

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

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

吧,ie9可能需刷新

var $id=function(n){

return document.getElementById(n) || n;

}

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

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

con.strokeStyle='#a00'

con.translate(300,100);

function draw(){

var r=0 , a=100 , start = 0 , end= 0 , k=4; //可以改变k值试试

for(var q=0; q<500; q++){

start += Math.PI * 2 /500;

end = start + Math.PI * 2 /500;

r =Math.abs(a *(Math.cos( k * start))) //玫瑰线公式r(θ) = a sin kθ

con.arc(0,0,r,start,end,false);

}

con.stroke();

}

/p>

html>

Archimedean spiral

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

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

吧,ie9可能需刷新

var $id=function(n){

return document.getElementById(n) || n;

}

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

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

con.strokeStyle='#a00'

con.translate(300,100);

function draw(){

var r=0 , a=20 , start = 0 , end= 0 , k=2;

for(var q=0; q<500; q++){

start += Math.PI * 2 /100;

end = start + Math.PI * 2 /100;

r =a + k * start //阿基米德螺线

con.arc(0,0,r,start,end,false);

}

con.stroke();

}

另外,出于审美需求,我们的心型图形往往是这样的:

17(x^2+y^2)-16*abs(x)*y=225

但是这里所用到的坐标系是直角坐标系,我们需转换成极坐标方程,如下:

r=sqrt(225/(17-16sinθ*sqrt((cosθ)^2)))

最后,是我们的canvas大显身手的时候了:

/p>

html>

LOVE

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

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

吧,ie9可能需刷新

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=20 , start = 0 , end= 0;

con.rotate(Math.PI);

for(var q=0; q<1000; q++){

start += Math.PI * 2 /1000;

end = start + Math.PI * 2 /1000;

r=a*Math.sqrt(225/(17-16*Math.sin(start)*Math.sqrt(Math.cos(start)*Math.cos(start))))

con.arc(0,0,r,start,end,false);

}

con.fill();

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信小程序--校园小情书后台源码,好玩的表白墙,告白墙。 小情书是一个开源项目,你可以使用叶子的后台服务,也可以自己搭建后台服务。本文档为独立部署小情书后台服务的教程。 项目环境要求: PHP 7.0以上 MySQL 5.7 docker部署方式(推荐) 使用docker部署,只需要五分钟即可,方便快捷,只需要配置一个docker-compose文件即可 一、部署docker环境(ubuntu) Docker 官方为了简化安装流程,提供了一套便捷的安装脚本,Ubuntu 系统上可以使用这套脚本安装: `` $ curl -fsSL get.docker.com -o get-docker.sh `` `` $ sudo sh get-docker.sh --mirror Aliyun `` 执行这个命令后,脚本就会自动的将一切准备工作做好,并且把 Docker CE 的 Edge 版本安装在系统中。 启动 Docker CE ``` $ sudo systemctl enable docker ``` ``` $ sudo systemctl start docker ```  输入以下命令检测docker是否安装好了 ``` $ docker -v ``` 如果打印出docker的版本信息即安装成功 二、安装docker-compose 如果你的操作系统是window或者mac的,安装docker的时候已经包含在里面了,无需再单独安装,如果你的是linux系统,需要按照下面的方法安装即可。 在 Linux 上的也安装十分简单,从 官方 GitHub Release 处直接下载编译好的二进制文件即可。 例如,在 Linux 64 位系统上直接下载对应的二进制包。 ``` $ sudo curl -L https://github.com/docker/compose/releases/download/1.17.1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose ``` ``` $ sudo chmod +x /usr/local/bin/docker-compose``` 如果安装docker-compose遇到问题可以直接搜索相关资料,有很多解决方案。 三、使用docker-compose.yml部署小情书后台 1、把小情书后台源码中的docker-compose.yml贴到你需要部署的目录中,然后配置后台项目需要的参数 docker-compose.yml文件 2、编辑docker-compose.yml文件,填写项目参数 只需要编辑红框中的这些参数即可,根据提示填上相应的参数,然后保存即可,数据库名称必须为love_wall,数据库的用户名称必须为root。 3、启动项目,执行命令 `docker-compose -up -d` 第一次启动会有点久,因为第一次需要拉取镜像,耐心等待 项目启动完成,docker-compose会启动  - nginx  - php-fpm  - mysql  - phpmyadmin. 注意: 本地通过访问127.0.0.1:8000即可访问项目 phpmyadmin通过127.0.0.1:8080访问,host为db,把项目目录下的love_wall.sql导入数据库即可 如果你是在本地window或者mac开发环境可以直接这样访问,如果是线上的云主机可以使用你的IP+端口来访问,云主机需要防火墙放开8000和8080端口才能访问,本地直接在浏览器打开访问即可,如果你想通过域名访问,需要在宿主机器上部署nginx来转发请求到127.0.0.1:8000和127.0.0.1:8080去访问项目和phpmyadmin 4、停止项目,执行以下命令停止项目 `docker-compose down` 如果想再次启动项目执行docker-compose up -d即可 手动部署方式: 一、下载后台源码 1.1直接下载后台源码 直接点击download下载源码即可 别忘了点右上角的star哈 Build Status 1.2使用git获取源码 在Git输入命令 git clone https://github.com/oubingbing/wechatAlliance.git 二、安装PHP包管理工具composer 安装 - Windows 使用安装程序 这是将 Composer 安装在你机器上的最简单的方法。 下载并且运行 Composer-Setup.exe,它将安装最新版本的 Composer ,并设置好系统的环境变量,因此你可以在任何目录下直接使用 composer 命令。 composer下

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值