婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > canvas實(shí)現(xiàn)高階貝塞爾曲線(N階貝塞爾曲線生成器)

canvas實(shí)現(xiàn)高階貝塞爾曲線(N階貝塞爾曲線生成器)

熱門標(biāo)簽:四川點(diǎn)撥外呼系統(tǒng) 南寧點(diǎn)撥外呼系統(tǒng)哪家公司做的好 電銷機(jī)器人電話用什么卡 江蘇智能電銷機(jī)器人哪家好 黃島區(qū)地圖標(biāo)注 云南大理400電話申請官方 成都智能外呼系統(tǒng)平臺 鎮(zhèn)江智能外呼系統(tǒng)有效果嗎 當(dāng)涂高德地圖標(biāo)注

寫在最前

由于原生的Canvas最高只支持到三階貝塞爾曲線,那么我想添加多個控制點(diǎn)怎么辦呢?(即便大部分復(fù)雜曲線都可以用3階貝塞爾來模擬)與此同時,關(guān)于貝塞爾控制點(diǎn)的位置我們很難非常直觀的清楚到底將控制點(diǎn)設(shè)置為多少可以形成我們想要的曲線。本著解決以上兩個痛點(diǎn)同時社區(qū)內(nèi)好像并沒有N階的解決方案(js版)故這次作者非常認(rèn)真的開源了bezierMaker.js!

bezierMaker.js理論上支持N階貝塞爾曲線的生成,同時提供了試驗(yàn)場供開發(fā)者可以自行添加并拖拽控制點(diǎn)最終生成一組繪制動畫。非常直觀的讓開發(fā)者知道不同位置的控制點(diǎn)所對應(yīng)的不同生成曲線。

如果你喜歡這個作品歡迎Star,畢竟star來之不易。。

項(xiàng)目地址:這里✨✨✨

為什么需要一個試驗(yàn)場?

在繪制復(fù)雜的高階貝塞爾曲線時無法知道自己需要的曲線的控制點(diǎn)的精確位置。在試驗(yàn)場中進(jìn)行模擬,可以實(shí)時得到控制點(diǎn)的坐標(biāo)值,將得到的點(diǎn)坐標(biāo)變?yōu)閷ο髷?shù)組傳遞進(jìn)BezierMaker類就可以生成目標(biāo)曲線

效果圖

 
 

功能

  1. [x] 試驗(yàn)場可添加任意數(shù)量控制點(diǎn)
  2. [x] 試驗(yàn)場支持展示曲線繪制的形成動畫
  3. [x] 控制點(diǎn)可自由拖拽
  4. [x] 支持顯示貝塞爾曲線形成過程的切線
  5. [x] 3階及以下貝塞爾曲線的繪制采用原生API

引入

<script src="./bezierMaker.js"></script>

繪制

上面的效果圖為試驗(yàn)場的使用,當(dāng)你通過試驗(yàn)場獲得控制點(diǎn)的準(zhǔn)確坐標(biāo)之后,就可以調(diào)用bezierMaker.js進(jìn)行曲線的直接繪制。

/**
 * canvas canvas的dom對象
 * bezierCtrlNodesArr 控制點(diǎn)數(shù)組,包含x,y坐標(biāo)
 * color 曲線顏色
 */
var canvas = document.getElementById('canvas')
//3階之前采用原生方法實(shí)現(xiàn)
var arr0 = [{x:70,y:25},{x:24,y:51}]
var arr1 = [{x:233,y:225},{x:170,y:279},{x:240,y:51}]
var arr2 = [{x:23,y:225},{x:70,y:79},{x:40,y:51},{x:300, y:44}]
var arr3 = [{x:333,y:15},{x:70,y:79},{x:40,y:551},{x:170,y:279},{x:17,y:239}]
var arr4 = [{x:53,y:85},{x:170,y:279},{x:240,y:551},{x:70,y:79},{x:40,y:551},{x:170,y:279}]
var bezier0 = new BezierMaker(canvas, arr0, 'black')
var bezier1 = new BezierMaker(canvas, arr1, 'red')
var bezier2 = new BezierMaker(canvas, arr2, 'blue')
var bezier3 = new BezierMaker(canvas, arr3, 'yellow')
var bezier4 = new BezierMaker(canvas, arr4, 'green')
bezier0.drawBezier()
bezier1.drawBezier()
bezier2.drawBezier()
bezier3.drawBezier()
bezier4.drawBezier()

繪制結(jié)果

當(dāng)控制點(diǎn)少于3個時,會適配使用原生的API接口。當(dāng)控制點(diǎn)多于2個后,由我們自己實(shí)現(xiàn)的函數(shù)進(jìn)行描點(diǎn)繪制。

核心原理

繪制貝塞爾曲線

繪制貝塞爾曲線的核心點(diǎn)在于貝塞爾公式的運(yùn)用:
 

 
 

這個公式中的P0-Pn代表了從起點(diǎn)到各個控制點(diǎn)再到終點(diǎn)的各點(diǎn)與占比t的各種冪運(yùn)算。

BezierMaker.prototype.bezier = function(t) { //貝塞爾公式調(diào)用
    var x = 0,
        y = 0,
        bezierCtrlNodesArr = this.bezierCtrlNodesArr,
        //控制點(diǎn)數(shù)組
        n = bezierCtrlNodesArr.length - 1,
        self = this
    bezierCtrlNodesArr.forEach(function(item, index) {
        if(!index) {
            x += item.x * Math.pow(( 1 - t ), n - index) * Math.pow(t, index) 
            y += item.y * Math.pow(( 1 - t ), n - index) * Math.pow(t, index) 
        } else {
        //factorial為階乘函數(shù)
            x += self.factorial(n) / self.factorial(index) / self.factorial(n - index) * item.x * Math.pow(( 1 - t ), n - index) * Math.pow(t, index) 
            y += self.factorial(n) / self.factorial(index) / self.factorial(n - index) * item.y * Math.pow(( 1 - t ), n - index) * Math.pow(t, index) 
        }
    })
    return {
        x: x,
        y: y
    }
}

對所有點(diǎn)進(jìn)行遍歷同時根據(jù)當(dāng)前占比t的值(0<=t<=1),計算出當(dāng)前在貝塞爾曲線上的點(diǎn)坐標(biāo)x,y。t的取值作者分成了1000份,即每次運(yùn)算t+=0.01。此時算出的x,y即所求的貝塞爾曲線分成了1000份之后的某一點(diǎn)。當(dāng)t值從0~1遍歷1000次后生成1000個x,y對應(yīng)坐標(biāo),依次描點(diǎn)畫線即可模擬出高階貝塞爾曲線。

對于貝塞爾公式的推導(dǎo)作者會在之后的文章中專門說明,現(xiàn)在你只需要知道我們通過貝塞爾公式計算出實(shí)際貝塞爾曲線被等分成了1000份的各點(diǎn),用直線連接各點(diǎn)后即可模擬出類曲線。

對于模擬場貝塞爾曲線生成動畫的實(shí)現(xiàn)

這個部分相關(guān)代碼可以參考這里

整體思路是用遞歸的方式來將每個一層控制點(diǎn)當(dāng)做1階貝塞爾函數(shù)來計算下一層控制點(diǎn)并對應(yīng)連線。具體邏輯作者會留到深入講解貝塞爾曲線公式原理的時候一起梳理一下試驗(yàn)場的動畫生成原理~

小結(jié)

作者一直想開源一些東西(但是菜,也沒啥能寫的),然而平時會用到的都被人寫了,再造輪子也沒別人寫得好。這次也算是發(fā)現(xiàn)了一個貌似空白一些的區(qū)域。所以非常鄭重的決定開源。貝塞爾的高級運(yùn)用在gayhub中大多是安卓的實(shí)現(xiàn),前端領(lǐng)域中還有很多地方可以更多的展開,歡迎討論~ 多多批評!

最后

項(xiàng)目地址:這里✨✨

試驗(yàn)場地址:一定進(jìn)來玩✨✨✨

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:南京 淮安 西寧 廣西 十堰 佳木斯 咸寧 酒泉

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《canvas實(shí)現(xiàn)高階貝塞爾曲線(N階貝塞爾曲線生成器)》,本文關(guān)鍵詞  canvas,實(shí)現(xiàn),高階,貝,塞爾,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《canvas實(shí)現(xiàn)高階貝塞爾曲線(N階貝塞爾曲線生成器)》相關(guān)的同類信息!
  • 本頁收集關(guān)于canvas實(shí)現(xiàn)高階貝塞爾曲線(N階貝塞爾曲線生成器)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲18色成人| 国产精品免费免费| 91色porny在线视频| 97se亚洲国产综合自在线不卡| 激情小说亚洲一区| 国产精品123| 99热精品国产| 日本精品一区二区三区四区的功能| 一本色道亚洲精品aⅴ| 91黄色激情网站| 91精品视频网| 久久久99免费| 国产精品久久一卡二卡| 专区另类欧美日韩| 性欧美大战久久久久久久久| 免费精品视频最新在线| 国产麻豆精品久久一二三| 粉嫩在线一区二区三区视频| 99re热这里只有精品视频| 欧美三级午夜理伦三级中视频| 日韩午夜激情免费电影| 国产午夜精品一区二区三区嫩草| 亚洲欧洲国产日本综合| 日韩电影在线一区| 高清不卡在线观看av| 91蜜桃在线观看| 精品久久一二三区| 亚洲精品美腿丝袜| 国产在线精品国自产拍免费| 色诱视频网站一区| 欧美zozo另类异族| 夜夜爽夜夜爽精品视频| 九九九精品视频| 91丨porny丨户外露出| 日韩女优电影在线观看| 亚洲老妇xxxxxx| 寂寞少妇一区二区三区| 在线观看国产91| 国产视频在线观看一区二区三区 | 日韩影院精彩在线| 高清不卡一区二区在线| 日韩免费电影一区| 亚洲五码中文字幕| 成人午夜视频免费看| 欧美一区二区三区小说| 亚洲人快播电影网| 成人在线一区二区三区| 精品动漫一区二区三区在线观看| 亚洲欧美日韩系列| 成人a级免费电影| 久久一区二区三区国产精品| 五月天国产精品| 欧美亚洲禁片免费| 亚洲免费视频中文字幕| 国产成人福利片| 精品电影一区二区三区| 日韩精品91亚洲二区在线观看| 91免费观看视频| 国产精品久久久久影院亚瑟 | 亚洲日本免费电影| 国产寡妇亲子伦一区二区| 日韩无一区二区| 性做久久久久久久久| 欧洲色大大久久| 亚洲综合免费观看高清完整版在线 | 麻豆免费看一区二区三区| 欧美中文字幕亚洲一区二区va在线| 中文字幕亚洲电影| 91小视频免费观看| 亚洲乱码国产乱码精品精可以看| 91尤物视频在线观看| 国产精品久99| 91视频91自| 亚洲精品国产高清久久伦理二区| 91猫先生在线| 一区二区三区蜜桃| 欧美日韩精品久久久| 图片区小说区国产精品视频| 欧美日韩高清一区二区不卡| 亚洲午夜视频在线观看| 欧美日韩情趣电影| 日本不卡高清视频| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 91浏览器在线视频| 亚洲一区在线播放| 欧美精品xxxxbbbb| 国模娜娜一区二区三区| 国产精品午夜春色av| 在线免费观看一区| 另类小说欧美激情| 中文av字幕一区| 91久久精品一区二区二区| 亚洲自拍偷拍网站| 亚洲精品一区二区三区福利| 风间由美性色一区二区三区| 成人欧美一区二区三区小说 | 日本高清不卡视频| 男女性色大片免费观看一区二区| 日韩精品资源二区在线| 成人午夜av在线| 亚洲高清三级视频| 久久人人爽人人爽| 在线精品亚洲一区二区不卡| 日韩中文字幕亚洲一区二区va在线| 精品福利在线导航| 欧美性生活久久| 国产高清视频一区| 亚洲国产aⅴ成人精品无吗| 欧美成人艳星乳罩| 在线视频你懂得一区| 国产成人亚洲精品狼色在线| 亚洲国产精品自拍| 日本一区二区高清| 日韩一区二区在线看| 91免费版在线| 国产精品99久久久久久久女警| 亚洲综合色成人| 国产精品久久久久影院色老大| 欧美一级二级在线观看| 色综合久久久网| 成人理论电影网| 老汉av免费一区二区三区| 亚洲一区二区精品视频| 国产欧美日本一区二区三区| 欧美videossexotv100| 欧洲一区二区av| 色综合天天狠狠| 成人激情av网| 国产激情一区二区三区桃花岛亚洲| 日韩精品91亚洲二区在线观看| 亚洲欧美色图小说| 国产日韩欧美精品在线| 精品国产伦一区二区三区免费| 欧美日韩国产一区| 欧美三区在线观看| 欧美亚洲愉拍一区二区| 在线观看亚洲成人| 91色porny| 色综合久久久久久久久久久| 91视频在线看| 日本韩国欧美在线| 欧美亚洲国产bt| 91免费版在线| 色噜噜狠狠色综合欧洲selulu| 91美女精品福利| 日本黄色一区二区| 欧美区视频在线观看| 777奇米四色成人影色区| 欧美精品第一页| 欧美成va人片在线观看| 日韩精品一区二区三区三区免费 | 国产精品69毛片高清亚洲| 国产在线精品视频| 成人黄色小视频| 91亚洲国产成人精品一区二三| 色综合久久中文综合久久牛| 欧美亚洲国产bt| 欧美大白屁股肥臀xxxxxx| 日韩免费性生活视频播放| 久久久99精品免费观看| 日韩美女啊v在线免费观看| 亚洲精品videosex极品| 视频一区二区欧美| 久久av老司机精品网站导航| 国产精品一二三四| 欧美综合在线视频| 日韩欧美中文字幕制服| 国产欧美一区二区三区沐欲| 亚洲免费资源在线播放| 日韩精品欧美精品| 国产激情偷乱视频一区二区三区| a亚洲天堂av| 91精品国产色综合久久| 国产午夜精品一区二区三区四区| 亚洲免费观看高清完整版在线观看熊| 亚洲国产精品久久不卡毛片| 精品一区二区在线免费观看| 99精品视频一区| 欧美一区二区三区视频| 欧美国产综合色视频| 亚洲成人激情自拍| 国产精品原创巨作av| 日本乱人伦aⅴ精品| 久久新电视剧免费观看| 一区二区三区精品在线| 国产一区二区影院| 91精品国产一区二区三区蜜臀| 欧美极品另类videosde| 日韩精品乱码av一区二区| 成人激情午夜影院| 制服丝袜成人动漫| 一区二区三区四区国产精品| 久久99国内精品| 欧美美女直播网站| 亚洲色图.com| 国产精品一区在线观看你懂的| 88在线观看91蜜桃国自产| 亚洲视频在线一区| 国产大陆a不卡| 日韩你懂的在线观看|