亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

canvas實現高階貝塞爾曲線(N階貝塞爾曲線生成器)

2024-08-26 00:20:18
字體:
來源:轉載
供稿:網友

寫在最前

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

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

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

項目地址:這里???

為什么需要一個試驗場?

在繪制復雜的高階貝塞爾曲線時無法知道自己需要的曲線的控制點的精確位置。在試驗場中進行模擬,可以實時得到控制點的坐標值,將得到的點坐標變為對象數組傳遞進BezierMaker類就可以生成目標曲線

效果圖

貝塞爾曲線生成器,n階貝塞爾曲線,高階貝塞爾曲線 
 

貝塞爾曲線生成器,n階貝塞爾曲線,高階貝塞爾曲線

功能

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

引入

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

繪制

上面的效果圖為試驗場的使用,當你通過試驗場獲得控制點的準確坐標之后,就可以調用bezierMaker.js進行曲線的直接繪制。

/** * canvas canvas的dom對象 * bezierCtrlNodesArr 控制點數組,包含x,y坐標 * color 曲線顏色 */var canvas = document.getElementById('canvas')//3階之前采用原生方法實現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()

繪制結果

貝塞爾曲線生成器,n階貝塞爾曲線,高階貝塞爾曲線

當控制點少于3個時,會適配使用原生的API接口。當控制點多于2個后,由我們自己實現的函數進行描點繪制。

核心原理

繪制貝塞爾曲線

繪制貝塞爾曲線的核心點在于貝塞爾公式的運用:
 

貝塞爾曲線生成器,n階貝塞爾曲線,高階貝塞爾曲線 
 

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

BezierMaker.prototype.bezier = function(t) { //貝塞爾公式調用    var x = 0,        y = 0,        bezierCtrlNodesArr = this.bezierCtrlNodesArr,        //控制點數組        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為階乘函數            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    }}

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

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

對于模擬場貝塞爾曲線生成動畫的實現

這個部分相關代碼可以參考這里

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

小結

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

最后

項目地址:這里??

試驗場地址:一定進來玩???

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品久久久久久久久中文字幕| 性色av香蕉一区二区| 国产中文字幕日韩| 久久中文字幕视频| 国产综合视频在线观看| 日韩美女免费线视频| 亚洲二区中文字幕| 国产精品流白浆视频| 欧美巨大黑人极品精男| 久久精品亚洲精品| 欧美精品www| 精品日本美女福利在线观看| 久热在线中文字幕色999舞| 久久91亚洲精品中文字幕奶水| 久久综合伊人77777蜜臀| 国产不卡在线观看| 国模吧一区二区三区| 欧美成人精品影院| 97精品久久久中文字幕免费| 国产精品高潮呻吟久久av野狼| 97国产真实伦对白精彩视频8| 亚洲一区二区免费| 国产福利精品在线| 欧美精品一二区| 国产97在线播放| 播播国产欧美激情| 成人精品福利视频| 亚洲精品视频免费在线观看| 亚洲国产精品久久久| 92版电视剧仙鹤神针在线观看| 久久精品成人欧美大片| 色偷偷av一区二区三区乱| 韩曰欧美视频免费观看| 福利微拍一区二区| 久久躁日日躁aaaaxxxx| 亚洲四色影视在线观看| 中文字幕精品av| 富二代精品短视频| 91精品国产精品| 成人久久精品视频| 久久精品影视伊人网| 国产精品香蕉在线观看| 不卡av电影在线观看| 91精品国产高清自在线| 亚洲美女喷白浆| 欧美日韩国产专区| 国产精品入口尤物| 色偷偷av一区二区三区| 日韩欧美中文免费| 亚洲第一av在线| 精品亚洲永久免费精品| 亚洲国产又黄又爽女人高潮的| 欧美中文字幕在线视频| 亚洲国语精品自产拍在线观看| 欧美一区在线直播| 欧美激情综合亚洲一二区| 国产一区二区日韩精品欧美精品| 国产女同一区二区| 精品一区二区电影| 91tv亚洲精品香蕉国产一区7ujn| 狠狠躁夜夜躁人人躁婷婷91| 2020欧美日韩在线视频| 国产va免费精品高清在线| 久久久久久久一区二区三区| 日韩一区二区三区国产| 岛国精品视频在线播放| 色综合久久中文字幕综合网小说| 按摩亚洲人久久| 91精品国产高清自在线看超| 97人洗澡人人免费公开视频碰碰碰| 日本高清不卡在线| 亚洲国产成人精品久久久国产成人一区| 国产成人亚洲精品| 日韩av电影在线免费播放| 国产欧美一区二区三区久久| 国产91色在线| 国产精品日日摸夜夜添夜夜av| 国产成人综合av| 欧美国产日韩一区二区三区| 深夜福利91大全| 欧美专区在线播放| 亚洲最大福利网| 国产美女久久久| 国产精品第2页| 日本国产一区二区三区| 欧美精品福利视频| 欧美日韩亚洲一区二区三区| 欧美黄网免费在线观看| 一个色综合导航| 欧美日韩激情视频| 欧美激情视频网址| 91高清视频在线免费观看| 岛国视频午夜一区免费在线观看| 日韩在线观看免费高清完整版| 亚洲视频电影图片偷拍一区| 亚洲精品网址在线观看| 九九精品视频在线| 久久久久久久999精品视频| 欧美成人久久久| 午夜剧场成人观在线视频免费观看| 亚洲国产天堂网精品网站| 9.1国产丝袜在线观看| 欧美大片免费观看在线观看网站推荐| 亚洲欧美另类自拍| 这里只有精品视频| 日韩在线观看你懂的| 亚洲精品色婷婷福利天堂| 91中文在线视频| 久久色在线播放| 青青久久av北条麻妃黑人| 欧美激情精品久久久久久黑人| 色综合视频网站| 国产伊人精品在线| 国产精品午夜视频| 久久久久久久久久久网站| 91精品在线国产| 亚洲伊人久久大香线蕉av| 亚洲黄页视频免费观看| 久久久久久九九九| 日本a级片电影一区二区| 亚洲欧美日韩国产中文| 伦理中文字幕亚洲| 国产精品一区二区三区毛片淫片| 日韩免费在线观看视频| 97碰在线观看| 国产精品视频在线播放| 日韩成人激情影院| 久久天天躁狠狠躁夜夜爽蜜月| 国产精品h片在线播放| 日本精品久久久| 国产精品免费久久久久影院| 性欧美xxxx交| 国产精品丝袜久久久久久高清| 日韩欧美福利视频| 国产精品91一区| 亚洲影视九九影院在线观看| 国产经典一区二区| 日韩av免费看网站| 亚洲国产成人精品电影| 日韩中文在线中文网三级| 992tv成人免费影院| 日韩一中文字幕| 在线播放国产一区二区三区| 国产精品国产三级国产aⅴ9色| 欧美一级大胆视频| 亚洲高清在线观看| 成人黄色av免费在线观看| 伊人久久久久久久久久久| 成人欧美一区二区三区在线| 米奇精品一区二区三区在线观看| 456亚洲影院| 国产99久久精品一区二区永久免费| 久久国产精品免费视频| 久久的精品视频| 久久影院免费观看| 欧美午夜无遮挡| 亚洲视频在线免费观看| 日本aⅴ大伊香蕉精品视频| yellow中文字幕久久| 亚洲一级免费视频| 高清欧美性猛交xxxx黑人猛交| 不卡在线观看电视剧完整版| 欧美巨乳美女视频| 国产在线不卡精品|