Raphaël 鼠标拖动,滚轮缩放js代码
博客专区 > forluv83 的博客 > 博客详情
Raphaël 鼠标拖动,滚轮缩放js代码
forluv83 发表于3年前
Raphaël 鼠标拖动,滚轮缩放js代码
  • 发表于 3年前
  • 阅读 458
  • 收藏 9
  • 点赞 0
  • 评论 2

腾讯云 技术升级10大核心产品年终让利>>>   

$(window).load(function() {
	var p = Raphael('canvas');
	p.cx = 0, p.cy = 0, p.cs = 1;
	p.canvas.style.backgroundColor = '#008080';
	$(window).resize(function() {
		p.setSize($('#canvas').width(), $('#canvas').height());
	});
	$(p.canvas).on('mousedown', function(e) {
		if (e.target == p.canvas) {
			this.ox = e.offsetX;
			this.oy = e.offsetY;
		}
	});
	$(p.canvas).on('mousemove', function(e) {
		if (e.target == p.canvas && this.ox) {
			var size = p.getSize();
			p.cx = p.cx - (e.offsetX - this.ox) / p.cs;
			p.cy = p.cy - (e.offsetY - this.oy) / p.cs;
			p.setViewBox(p.cx, p.cy, size.width / p.cs, size.height / p.cs);
			this.ox = e.offsetX;
			this.oy = e.offsetY;
		}
	});
	$(p.canvas).on('mouseup', function(e) {
		if (e.target == p.canvas && this.ox) {
			delete this.ox;
			delete this.oy;
		}
	});
	$(p.canvas).on('mousewheel', function(e) {
		if (e.target == p.canvas) {
			var size = p.getSize();
			p.cs2 = e.originalEvent.wheelDelta > 0 ? p.cs * 1.125 : p.cs / 1.125;
			p.cx = p.cx + (e.offsetX / p.cs - e.offsetX / p.cs2);
			p.cy = p.cy + (e.offsetY / p.cs - e.offsetY / p.cs2);
			p.cs = p.cs2;
			p.setViewBox(p.cx, p.cy, size.width / p.cs, size.height / p.cs);
		}
		return false;
	});
	for (var i = 0; i < 200; i++) {
		var r = Math.random;
		p.rect(700 * r(), 500 * r(), 100 * r(), 100 * r()).attr('fill', '#00ffff');
	}
});


共有 人打赏支持
粉丝 4
博文 17
码字总数 5721
评论 (2)
湖心亭看雪
弱弱的问一句这个代码是做什么的?实现鼠标绘图?
forluv83

引用来自“湖心亭看雪”的评论

弱弱的问一句这个代码是做什么的?实现鼠标绘图?

类似百度地图上面,移动缩放地图的功能
×
forluv83
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: