JavaScript计算N个点均匀排列成圆的各个点坐标

这个方法可以用来支持圆形菜单布局等类似需求:

/**
 * 计算N个点均匀排列成圆的各个点坐标
 * @param nodeSize 参与排列成圆的元素个数
 * @param center 圆的中心点坐标 {x:, y:}
 * @param radius 圆的半径
 * @return 各个元素的坐标:[{x:, y:}, {x:, y:}, ...]
 */
function calcCircularLayout(nodeSize, center, radius) {
	var i, _i, _layouts = [];
	for(i = _i = 0; _i < nodeSize; i = ++_i) {
		var x = center.x + radius * Math.sin(2 * Math.PI * i / nodeSize),
		    y = center.y + radius * Math.cos(2 * Math.PI * i / nodeSize);

		_layouts.push({'x': x, 'y': y});
	}

	return _layouts;
}


转载于:https://my.oschina.net/jsan/blog/487353

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值