亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > canvas里面如何基于隨機點繪制一個多邊形的方法

canvas里面如何基于隨機點繪制一個多邊形的方法

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

起因

今天在學習《HTML5+Javascript動畫基礎》這本書的時候,在第八章的第三節講到如何用三個彈簧連接三個點來做拉伸運動。

在做完例子之后,就想到如果是四個點,五個點,怎么樣。

就改寫了一下代碼,把點的數目變量化。最終的效果是能實現各個點最終的拉伸運動到平衡,可是點之間的連線不是很好看,有些是交叉的。

于是就想著能不能優化這一塊。

旋轉連線

前面例子里面的點,都是隨機位置,所以連線不可控。所以想先從這塊著手。

先以某一個點為參照點,獲得其他點相對于這個點的角度。

然后按照角度從小到大的去連接這些點,這樣就能畫出一個正常的多邊形了。

大致實現代碼如下:

let balls = [];
let ballNum = 6;
let firstBall = null;
while(ballNum--) {
  let ball = new Ball(20, parseColor(Math.random() * 0xffffff))
  ball.x = Math.random() * width;
  ball.y = Math.random() * height;
  balls.push(ball)

  if (!firstBall) {
    firstBall = ball
    ball.angle = 0
  } else {
    const dx = ball.x - firstBall.x,
          dy = ball.y - firstBall.y;

    ball.angle = Math.atan2(dy, dx);
  }
}

// 嘗試讓球連線是一個正多邊形
balls = balls.sort((ballA, ballB) => {
  return ballA.angle - ballB.angle
})

這樣在最后繪制連線的時候,遍歷數組就能按照角度從小到大來繪制了。

效果如下:

這樣是能極大的減少交叉線的情況,可還是無法完全避免。

接下來,想嘗試優化這個方案,比如angle用Math.abs來取正,或者每一個點都找夾角最小的點來連線。可是結果都不行,無法避免交叉線。

基于中心點旋轉

后面又想到一個思路,如果能確定多邊形的中心點,那么分別計算所有點相對于中心點的夾角,就能以順時針或者逆時針來連接這些點。

可是在網上找了半天,所有點算法里面,都是要求有一系列按某個時針順序排列的點。

可是如果我有這些點,就已經能繪制多邊形了。只好放棄

X軸兩極點分割

無奈之下只好找Google,然后就發現了知乎上的一個答案挺好的: 如何將平面上無序的一組點連成一個簡單多邊形?

具體算法描述,大家看那個答案就好,我就不贅述了。

不過在連接上鏈和下鏈的時候,其實只要保證上鏈是X軸降序連接,下鏈是X軸升序連接即可(以逆時針方向繪制)。至于X軸相同的點,不管是優先Y軸大的還是小的都可以。

實現的時候,是嚴格按照答案里面的算法實現的。

在判斷一個點是屬于上鏈還是下鏈的時候,一開始想的是基于兩點確定直線的函數方程,再引入點的坐標來計算。不過后面想到,所有的點都以最左邊的極點來計算斜角,然后根據角度大小來劃分,視覺上更好理解。

大致代碼如下:

let balls = [];
let tempBalls = [];
let ballNum = 6;
let isDragingBall = false;

while(ballNum--) {
  let ball = new Ball(10, parseColor(Math.random() * 0xffffff))
  ball.x = Math.random() * width;
  ball.y = Math.random() * height;
  tempBalls.push(ball)
}

// 讓點按X軸升序排序
tempBalls = tempBalls.sort((ballA, ballB) => {
  return ballA.x - ballB.x
})

// 找X軸左右極點
let firstBall = tempBalls[0],
    lastBall = tempBalls[tempBalls.length -1];
let smallXBalls = tempBalls.filter(ball => ball.x === firstBall.x),
    bigXBalls = tempBalls.filter(ball => ball.x === lastBall.x)

// 處理左右極點有多個的情況
if (smallXBalls.length > 1) {
  smallXBalls.sort((ballA, ballB) => {
    return ballB.y - ballA.y
  })
}
if (bigXBalls.length > 1) {
  bigXBalls.sort((ballA, ballB) => {
    return ballB.y - ballA.y
  })
}

firstBall = smallXBalls[0]
lastBall = bigXBalls[0]

// 獲得極點連線的角度
let splitLineAngle = Math.atan2(lastBall.y - firstBall.y, lastBall.x - firstBall.x);
let upperBalls = [],
    lowerBalls = [];

// 所有其他點跟firstBall計算角度
// 大于splitLineAngle的都是下鏈
// 其他是上鏈
tempBalls.forEach(ball => {
  if (ball === firstBall || ball === lastBall) {
    return false
  }
  let angle = Math.atan2(ball.y - firstBall.y, ball.x - firstBall.x);
  if (angle > splitLineAngle) {
    lowerBalls.push(ball)
  } else {
    upperBalls.push(ball)
  }
})

// 處理X軸相同情況的排序
lowerBalls = lowerBalls.sort((ballA, ballB) => {
  if (ballA.x !== ballB.x) {
    return ballA.x - ballB.x
  }
  return ballB.y - ballA.y
})

upperBalls = upperBalls.sort((ballA, ballB) => {
  if (ballA.x !== ballB.x) {
    return ballB.x - ballA.x
  }
  return ballB.y - ballB.x
})

// 逆時針連接所有的點
balls = [firstBall].concat(lowerBalls, [lastBall], upperBalls)

balls = balls.map((ball, i) => {
  ball.text = i + 1;
  return ball
})

最終返回的balls,就是按逆時針排序的多邊形的點了。

效果如下:

各個球的內部狀態如下:

 

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

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

巨人網絡通訊聲明:本文標題《canvas里面如何基于隨機點繪制一個多邊形的方法》,本文關鍵詞  canvas,里面,如何,基于,隨機,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas里面如何基于隨機點繪制一個多邊形的方法》相關的同類信息!
  • 本頁收集關于canvas里面如何基于隨機點繪制一個多邊形的方法的相關信息資訊供網民參考!
  • 推薦文章
    精品视频在线看 | 日韩专区亚洲综合久久| 精品国产一区二区三区久久久蜜臀 | 韩国三级视频网站| 韩国毛片免费| 欧美激情在线精品video| 久久久久久久网| 精品视频在线观看免费| 亚洲 男人 天堂| 日韩免费在线| 国产精品自拍在线| 欧美α片无限看在线观看免费| 国产成人精品综合| 国产伦精品一区二区三区在线观看| 国产91丝袜在线播放0| 九九精品久久| 欧美爱色| 黄视频网站在线看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日本伦理网站| 日韩中文字幕一区| 国产视频网站在线观看| 一级毛片看真人在线视频| 精品久久久久久免费影院| 欧美国产日韩一区二区三区| 国产韩国精品一区二区三区| 青青久久精品国产免费看| 欧美一区二区三区性| 亚欧成人乱码一区二区| 日韩免费片| 国产a视频| 日韩免费片| 国产麻豆精品免费密入口| 国产成a人片在线观看视频| 日韩字幕在线| 精品国产一区二区三区久久久蜜臀| 国产亚洲免费观看| 欧美激情影院| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美激情一区二区三区视频高清| 999久久66久6只有精品| 欧美另类videosbestsex| 国产成人欧美一区二区三区的| 青青青草影院| 精品久久久久久中文字幕一区| 亚洲精品永久一区| 精品视频在线看 | 成人高清免费| a级黄色毛片免费播放视频| 国产网站免费在线观看| 国产亚洲精品aaa大片| 国产成人啪精品| 欧美大片a一级毛片视频| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产伦精品一区二区三区在线观看| 一级片免费在线观看视频| 精品视频在线观看一区二区| 国产麻豆精品hdvideoss| 日日夜人人澡人人澡人人看免| 精品视频免费观看| 一本伊大人香蕉高清在线观看| 精品久久久久久中文| 欧美日本国产| 国产一级生活片| 成人影院久久久久久影院| 精品在线免费播放| 国产原创视频在线| 中文字幕一区二区三区精彩视频 | 色综合久久天天综合绕观看| 成人a级高清视频在线观看| 四虎影视久久久免费| 欧美爱色| 欧美日本免费| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 美国一区二区三区| 精品久久久久久免费影院| 韩国三级视频网站| 国产成人欧美一区二区三区的| 可以免费在线看黄的网站| 日韩在线观看免费| 一级女人毛片人一女人| 亚洲不卡一区二区三区在线| 精品国产一区二区三区久久久蜜臀| 黄色福利片| 九九热国产视频| 欧美激情一区二区三区视频| 天堂网中文字幕| 人人干人人插| 国产一区二区精品久| 日韩专区一区| 国产精品免费久久| 九九久久99| 国产一区二区精品尤物| 九九精品久久久久久久久| 四虎影视久久| 国产精品自拍亚洲| 精品国产香蕉在线播出| 国产亚洲精品aaa大片| 韩国毛片免费| 欧美另类videosbestsex久久| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 欧美a免费| 欧美一级视| 青青久久精品| 精品视频在线观看免费| 久久久成人网| 国产成人精品在线| 九九精品久久| 久久久久久久网| 亚洲女初尝黑人巨高清在线观看| 亚洲 国产精品 日韩| 可以免费看毛片的网站| 91麻豆tv| 国产精品1024永久免费视频 | 天天做人人爱夜夜爽2020毛片| 国产成人精品综合| 高清一级做a爱过程不卡视频| 天天做人人爱夜夜爽2020毛片| 一级女性大黄生活片免费| 亚洲 欧美 91| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美激情中文字幕一区二区| 天天色色色| 日韩免费片| 精品国产一区二区三区精东影业| 人人干人人插| 99热精品在线| 国产麻豆精品| 欧美爱爱动态| 成人高清护士在线播放| 欧美电影免费| 国产亚洲男人的天堂在线观看| 亚洲女初尝黑人巨高清在线观看| 成人av在线播放| 精品视频免费观看| 精品视频一区二区三区| 国产国产人免费视频成69堂| 国产国产人免费视频成69堂| 青青青草影院| 久久久久久久久综合影视网| 青草国产在线| 成人在激情在线视频| a级毛片免费全部播放| 亚洲精品久久玖玖玖玖| 香蕉视频亚洲一级| 台湾毛片| 欧美激情一区二区三区中文字幕| 亚欧视频在线| 欧美激情一区二区三区视频高清| 免费一级生活片| 日日日夜夜操| 999久久久免费精品国产牛牛| 一级毛片视频免费| 成人免费观看男女羞羞视频| 国产伦久视频免费观看 视频| 成人a级高清视频在线观看| 国产视频久久久| 99热精品在线| 国产精品自拍亚洲| 免费国产在线视频| 欧美a级大片| 国产美女在线一区二区三区| 国产亚洲精品aaa大片| 欧美大片aaaa一级毛片| 国产一级生活片| 日本伦理网站| 精品视频一区二区三区| 二级片在线观看| 午夜激情视频在线观看| 午夜精品国产自在现线拍| 欧美激情伊人| 欧美一级视频免费| 香蕉视频三级| 日韩在线观看视频网站| 欧美日本韩国| 国产成人精品在线| 欧美激情一区二区三区在线| 欧美激情在线精品video| 成人影院久久久久久影院| 欧美爱爱动态| 91麻豆国产| 成人影院久久久久久影院| 精品国产三级a| 韩国三级香港三级日本三级la| 日韩av片免费播放| 国产一区二区精品久| 日韩免费在线视频| 免费一级片在线观看| 黄视频网站免费观看| 999久久狠狠免费精品| 午夜欧美福利| 午夜欧美福利| 国产视频一区在线| 97视频免费在线观看| 日本免费区| 亚洲精品永久一区| 91麻豆国产级在线| 黄视频网站在线免费观看| 一本高清在线| 午夜在线影院|