用canvas畫一個愛心

首先找了一個心形線公式:

x=12*sin(t)-4*sin(3*t)

y=13*cos(t)-5*cos(2*t)-2*cos(3*t)-cos(4*t)

代碼如下:

function heart() {

? ? ? ? const c = document.getElementById("myCanvas");

? ? ? ? const ctx = c.getContext("2d");

? ? ? ? //設(shè)置初始弧度

? ? ? ? let radian = 0;

? ? ? ? //設(shè)置弧度增量曲饱,每次增加1°

? ? ? ? let radian_add = Math.PI / 180;

? ? ? ? //開始繪圖

? ? ? ? ctx.beginPath();

? ? ? ? // 重新映射畫布上的 (0,0) 位置

? ? ? ? ctx.translate(250, 200);

? ? ? ? // 設(shè)置繪制起點

? ? ? ? ctx.moveTo(getX(radian), getY(radian));

? ? ? ? // 弧度小于等于360°

? ? ? ? while (radian <= Math.PI * 2) {

? ? ? ? ? //每增加一次弧度,繪制一條線

? ? ? ? ? radian += radian_add;

? ? ? ? ? X = getX(radian);

? ? ? ? ? Y = getY(radian);

? ? ? ? ? ctx.lineTo(X, Y);

? ? ? ? }

? ? ? ? ctx.strokeStyle = "red";

? ? ? ? ctx.stroke();

}

//獲取心型線的X坐標捣染,放大15倍

function getX(t) {

? ? ? ? return 15 * (12 * Math.sin(t) - 4 * Math.sin(3 * t));

}

//獲取心型線的Y坐標把兔,放大15倍

function getY(t) {

? ? ? ? return (

? ? ? ? ? -15 *

? ? ? ? ? (13 * Math.cos(t) -

? ? ? ? ? ? 5 * Math.cos(2 * t) -

? ? ? ? ? ? 2 * Math.cos(3 * t) -

? ? ? ? ? ? Math.cos(4 * t))

? ? ? ? );

}

實現(xiàn)效果如下蟀伸,可在線查看效果

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末僵闯,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子癞谒,更是在濱河造成了極大的恐慌底燎,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,270評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件弹砚,死亡現(xiàn)場離奇詭異双仍,居然都是意外死亡,警方通過查閱死者的電腦和手機桌吃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評論 3 395
  • 文/潘曉璐 我一進店門朱沃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人茅诱,你說我怎么就攤上這事逗物。” “怎么了瑟俭?”我有些...
    開封第一講書人閱讀 165,630評論 0 356
  • 文/不壞的土叔 我叫張陵翎卓,是天一觀的道長。 經(jīng)常有香客問我尔当,道長莲祸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,906評論 1 295
  • 正文 為了忘掉前任椭迎,我火速辦了婚禮锐帜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘畜号。我一直安慰自己缴阎,他們只是感情好,可當我...
    茶點故事閱讀 67,928評論 6 392
  • 文/花漫 我一把揭開白布简软。 她就那樣靜靜地躺著蛮拔,像睡著了一般述暂。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上建炫,一...
    開封第一講書人閱讀 51,718評論 1 305
  • 那天畦韭,我揣著相機與錄音,去河邊找鬼肛跌。 笑死艺配,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的衍慎。 我是一名探鬼主播转唉,決...
    沈念sama閱讀 40,442評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼稳捆!你這毒婦竟也來了赠法?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,345評論 0 276
  • 序言:老撾萬榮一對情侶失蹤乔夯,失蹤者是張志新(化名)和其女友劉穎砖织,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體驯嘱,經(jīng)...
    沈念sama閱讀 45,802評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡镶苞,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,984評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了鞠评。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片茂蚓。...
    茶點故事閱讀 40,117評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖剃幌,靈堂內(nèi)的尸體忽然破棺而出聋涨,到底是詐尸還是另有隱情,我是刑警寧澤负乡,帶...
    沈念sama閱讀 35,810評論 5 346
  • 正文 年R本政府宣布牍白,位于F島的核電站,受9級特大地震影響抖棘,放射性物質(zhì)發(fā)生泄漏茂腥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,462評論 3 331
  • 文/蒙蒙 一切省、第九天 我趴在偏房一處隱蔽的房頂上張望最岗。 院中可真熱鬧,春花似錦朝捆、人聲如沸般渡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽驯用。三九已至脸秽,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蝴乔,已是汗流浹背记餐。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留薇正,地道東北人剥扣。 一個月前我還...
    沈念sama閱讀 48,377評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像铝穷,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子佳魔,可洞房花燭夜當晚...
    茶點故事閱讀 45,060評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 一:canvas簡介 1.1什么是canvas曙聂? ①:canvas是HTML5提供的一種新標簽 ②:HTML5 ...
    GreenHand1閱讀 4,685評論 2 32
  • 最終效果 ##一、定義初始變量 letradius =140//外環(huán)半徑letthickness =20//圓環(huán)厚...
    ican_6da9閱讀 990評論 0 0
  • 上網(wǎng)搜索了angularjs裁剪鞠鲜,發(fā)現(xiàn)只有正方形和圓形 http://www.cnblogs.com/smilec...
    四腳蛇閱讀 733評論 0 1
  • 最基本的使用創(chuàng)建一個畫布所有的操作都在畫布的context上面canvas是基于狀態(tài)而不是基于對象的宁脊,比如說顏色都...
    親愛的孟良閱讀 1,658評論 0 4
  • https://blog.csdn.net/feiyunjs/article/details/94722766 /...
    FsdSoyu閱讀 969評論 0 0