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

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

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

熱門標簽:四川點撥外呼系統 南寧點撥外呼系統哪家公司做的好 電銷機器人電話用什么卡 江蘇智能電銷機器人哪家好 黃島區地圖標注 云南大理400電話申請官方 成都智能外呼系統平臺 鎮江智能外呼系統有效果嗎 當涂高德地圖標注

寫在最前

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

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

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

項目地址:這里✨✨✨

為什么需要一個試驗場?

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

效果圖

 
 

功能

  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()

繪制結果

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

核心原理

繪制貝塞爾曲線

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

 
 

這個公式中的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中大多是安卓的實現,前端領域中還有很多地方可以更多的展開,歡迎討論~ 多多批評!

最后

項目地址:這里✨✨

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

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

標簽:南京 淮安 西寧 廣西 十堰 佳木斯 咸寧 酒泉

巨人網絡通訊聲明:本文標題《canvas實現高階貝塞爾曲線(N階貝塞爾曲線生成器)》,本文關鍵詞  canvas,實現,高階,貝,塞爾,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas實現高階貝塞爾曲線(N階貝塞爾曲線生成器)》相關的同類信息!
  • 本頁收集關于canvas實現高階貝塞爾曲線(N階貝塞爾曲線生成器)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩一区二区电影| 国产精品美女久久久久久2018| 另类成人小视频在线| 日产国产欧美视频一区精品| 天天射综合影视| 蜜桃精品在线观看| 成人的网站免费观看| 色欧美片视频在线观看 | 精品国产电影一区二区| 国产精品女人毛片| 日本女人一区二区三区| 成人黄色777网| 日韩欧美亚洲国产另类| 国产精品美女久久久久久久久| 五月综合激情日本mⅴ| 国产91在线观看丝袜| 欧美区一区二区三区| 国产亚洲精品免费| 亚洲成人福利片| 不卡一区二区三区四区| 欧美精品三级在线观看| 国产精品久久看| 精品中文av资源站在线观看| 色狠狠色狠狠综合| 国产欧美综合色| 奇米影视在线99精品| 色欧美日韩亚洲| 亚洲欧美综合网| 国产又黄又大久久| 亚洲男同1069视频| 五月天一区二区三区| 欧美浪妇xxxx高跟鞋交| 国产suv精品一区二区三区| 婷婷中文字幕综合| 亚洲天堂久久久久久久| 久久影音资源网| 7777女厕盗摄久久久| av一区二区三区四区| 美女视频黄 久久| 亚洲国产精品一区二区久久| 中文字幕不卡三区| 久久亚洲免费视频| 日韩一区二区在线观看视频| 欧美美女直播网站| 成人黄色a**站在线观看| 激情欧美日韩一区二区| 天堂精品中文字幕在线| 一片黄亚洲嫩模| 中国色在线观看另类| 精品国产91久久久久久久妲己| 欧美日本在线观看| 日本乱人伦aⅴ精品| 成人精品国产一区二区4080| 国产精品系列在线播放| 老色鬼精品视频在线观看播放| 亚洲香蕉伊在人在线观| 亚洲美女电影在线| 中文字幕综合网| 国产精品视频一二| 国产欧美一二三区| 欧美经典一区二区| 久久久久久久久久久99999| 91在线观看视频| 成人小视频在线观看| 精品电影一区二区三区| 国产精品日韩成人| 国产不卡在线视频| 国产精品久久久久久久久久免费看 | 91女厕偷拍女厕偷拍高清| 久久婷婷成人综合色| 国产一区二区三区四| 久久久久久电影| 久久99久久99小草精品免视看| 亚洲韩国精品一区| 性感美女极品91精品| 一区二区三区在线视频观看| 中文字幕精品一区二区三区精品| 国产精品99久久久久久似苏梦涵| 久久精品国产77777蜜臀| 亚洲成av人在线观看| 午夜私人影院久久久久| 日韩国产欧美在线播放| 免费人成精品欧美精品| 国产一区在线观看视频| 国产精品亚洲综合一区在线观看| 日韩精品专区在线| 亚洲欧美激情小说另类| 欧美一二三在线| 高清在线不卡av| 亚洲综合网站在线观看| 精品国产一区二区精华| 99re成人精品视频| 日韩不卡在线观看日韩不卡视频| 久久久激情视频| 色8久久精品久久久久久蜜| 久久爱另类一区二区小说| 亚洲欧美在线aaa| 精品少妇一区二区三区免费观看| 92国产精品观看| 久久91精品久久久久久秒播| 亚洲美女免费视频| www久久精品| 欧美美女一区二区三区| 成人天堂资源www在线| 日韩精品一级二级| 国产精品久久久久久久久久免费看 | 欧美撒尿777hd撒尿| 国产综合一区二区| 亚洲尤物视频在线| 久久久国际精品| 91精品欧美福利在线观看| av亚洲精华国产精华| 看电影不卡的网站| 亚洲电影第三页| 1024成人网| 国产欧美一区二区在线| 欧美高清你懂得| 欧美探花视频资源| 色婷婷综合久久| 99久久久久久| 丰满少妇久久久久久久| 激情av综合网| 免费一级欧美片在线观看| 一区二区三区久久| 国产精品国产三级国产有无不卡 | 精品精品国产高清a毛片牛牛| 色激情天天射综合网| 久久久www成人免费毛片麻豆| 色婷婷av一区二区三区软件| 成人一区二区三区视频| 国产一区二区三区免费| 亚洲国产精品尤物yw在线观看| 国产91丝袜在线播放0| 91麻豆精品国产91久久久使用方法| 中文一区在线播放| 久久99精品国产| 欧美专区在线观看一区| 久久久久久久久一| 久久精品av麻豆的观看方式| 欧美无砖专区一中文字| 中文字幕视频一区| 成人中文字幕在线| 亚洲精品在线网站| 天天影视涩香欲综合网| 在线观看成人免费视频| 国产精品伦一区| 国产精品亚洲一区二区三区在线| 欧美精品一级二级| 亚洲自拍偷拍欧美| 99国产精品久久久久久久久久| 国产午夜三级一区二区三| 日韩成人精品视频| 777亚洲妇女| 婷婷久久综合九色综合伊人色| 欧洲在线/亚洲| 亚洲欧洲日韩一区二区三区| 国产成人aaa| 欧美激情一区在线观看| 国产精品主播直播| 欧美国产精品久久| 国产露脸91国语对白| 精品成人在线观看| 精品亚洲aⅴ乱码一区二区三区| 欧美一级久久久| 蜜桃av一区二区在线观看| 日韩欧美第一区| 韩国中文字幕2020精品| 久久综合久久99| 国产精品一区二区三区乱码| 久久综合色婷婷| 国产二区国产一区在线观看| 久久精品日产第一区二区三区高清版| 国产麻豆精品久久一二三| 2014亚洲片线观看视频免费| 国产精品一区二区黑丝| 久久精品国产第一区二区三区| 日韩1区2区日韩1区2区| 国产精品99久久久| 色偷偷久久人人79超碰人人澡| 欧美一级专区免费大片| 国产精品久久久久久久久图文区| 五月天国产精品| 99久久精品国产导航| 欧美一区二区精品久久911| 国产欧美日韩综合精品一区二区| 亚洲图片一区二区| 一区二区三区免费| 色综合激情五月| 亚洲成人午夜影院| 日韩欧美成人激情| 成人国产视频在线观看| 亚洲精品国产视频| 91.com视频| 国产欧美日韩精品在线| 成人av电影免费观看| 亚洲一二三区视频在线观看| 欧美不卡在线视频| 99在线精品视频| 首页国产欧美日韩丝袜| 久久天天做天天爱综合色|