本文实例为大家分享了js实现固定区域内的不重叠随机圆,供大家参考,具体内容如下
关键词:js、固定区域、不重叠、随机圆,半径固定、半径随机
最近公司有一个需求就是在一个固定的区域(500X500)内显示10个圆,且半径固定,而且不重叠
因为圆的个数固定,而且半径固定,那么就有可能会没有解决方案。
不过其实也没有很难,处理好半径的最大值就好了。
效果图:
思路:
(固定半径)
step1:先在区域内生成一个随机的圆心坐标,
step2:然后拿一个固定半径(从大到小拿固定半径)
step3:判断圆心和半径是否合法(是否超边距,或者两个圆相交)
step4:如果不合法,重新执行step2和step3
step5:如果合法,记为一个新圆
step6:重复step1~5,直到生成10个圆
(随机半径)
step1:先在区域内生成一个随机的圆心坐标,
step2:根据圆心坐标,与其他圆比较,获取最短的圆心距减去比较圆的半径(圆心距-R n RnR_n)的值,作为新圆的半径(这样就会生成一个相切的圆)
step3:判断圆心和半径是否合法(是否超边距)
step4:如果不合法,重新执行step2和step3
step5:如果合法,记为一个新圆
step6:重复step1~5,直到生成10个圆
代码:
// 参数 let obj = { id: string, // canvas 的id fix:boolean, // 是否固定半径,默认为false minMargin: Number, // 两个圆的最短距离,默认为10 minRadius: Number, 最小的圆半径,默认为30 radiuArr: Array, 圆的半径的数组,当fix为true时该值必须填 total: Number ,圆的个数,默认为10 }
<!DOCTYPE html> <html> <body> <canvas id="myCanvas" width="500" height="500" style="border:1px solid #d3d3d3;"> Your browser does not support the HTML5 canvas tag. </canvas> <script> class Circle { constructor(x, y, r, color){ this.x = x this.y = y this.r = r, this.c = color "2d"); this.dWidth = this.c.width; this.dHeight = this.c.height this.fix = obj.fix || false; this.minMargin = obj.minMargin || 10 this.minRadius = obj.minRadius || 30 this.radiuArr = obj.radiuArr || [80,70,60,50,45,40,40,35,35,30] this.total = obj.total || 10 this.circleArray = [] this.circleNumber = 1 } drawOneCircle(c) { let ctx = this.ctx; ctx.beginPath(); ctx.strokeStyle = c.c; ctx.fillStyle=c.c; ctx.arc(c.x, c.y, c.r, 0, 2*Math.PI); ctx.stroke(); ctx.fill(); ctx.fillStyle='black'; ctx.fillText('No:'+this.circleNumber, c.x-10, c.y-5); ctx.fillText('R:'+c.r, c.x-10, c.y+5); this.circleNumber ++ } check(x,y,r) { return !(x+r > this.dWidth || x-r < 0 || y + r > this.dHeight || y-r < 0) } // 获取一个新圆的半径,主要判断半径与最近的一个圆的距离 getR(x,y) { if (this.circleArray.length === 0) return Math.floor(Math.random()*20 + 80) let lenArr = this.circleArray.map(c => { let xSpan = c.x-x let ySpan = c.y-y return Math.floor(Math.sqrt(Math.pow(xSpan,2) + Math.pow(ySpan,2))) - c.r }) let minCircleLen = Math.min(...lenArr) let minC = this.circleArray[lenArr.indexOf(minCircleLen)] let tempR = this.fix ? this.radiuArr[this.circleArray.length] : minCircleLen - this.minMargin let bool = this.fix ? (tempR <= minCircleLen - minC.r) : (tempR >= this.minRadius) return bool ? tempR : false } // 生成一个圆,随机生成圆心。 // 如果连续生成200次半径都没有合适的话,终止进程 createOneCircle(){ let x,y,r; let createCircleTimes = 0 while(true) { createCircleTimes ++ x = Math.floor(Math.random()*this.dWidth) y = Math.floor(Math.random()*this.dHeight) let TR = this.getR(x,y) if (!TR) { continue; } else { r = TR } if (this.check(x,y,r) || createCircleTimes > 200) { break } } this.check(x,y,r) && this.circleArray.push(new Circle(x, y, r)) } // 如果生成100次新圆都失败的话,终止方案。 // 如果生成100种方案都没有合适可用的话,终止进程。 init() { let n = 0 while(this.circleArray.length < this.total) { this.circleArray = [] let i = 0; while (this.circleArray.length < this.total) { this.createOneCircle() i ++ if (i >= 100) { break; } } n ++ if (n > 100) { break; } } // 根据半径从大到小画圆。 this.circleArray.sort( (a,b) => b.r-a.r).forEach(c => { this.drawOneCircle(c) }) } } let p = new RandomCircle({id: 'myCanvas', total: 20}) p.init() console.log(p.circleArray) </script> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]