文档章节

Raphaël 鼠标拖动,滚轮缩放js代码

forluv83
 forluv83
发布于 2015/04/05 01:17
字数 156
阅读 582
收藏 9
$(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');
	}
});


© 著作权归作者所有

共有 人打赏支持
forluv83
粉丝 3
博文 19
码字总数 5721
作品 0
东城
高级程序员
私信 提问
加载中

评论(2)

forluv83
forluv83

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

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

类似百度地图上面,移动缩放地图的功能
湖心亭看雪
湖心亭看雪
弱弱的问一句这个代码是做什么的?实现鼠标绘图?
完全免费开源!开发者用了都说好的5款JavaScript图表库

用过不少的商用图表工具&图表库,比如Fusioncharts、AmChart,技术服务好,厂家的支持给力,总是物有所值。随着一些产品的开源,除了商用图表,现在也开始关注开源图表工具了。虽然和Fusionc...

周宇YuZhou
2015/07/02
0
0
Raphaël 基于html5绘制web图形的javascript插件

昨天在群里看到一个海归妹子的个人兼应聘作品网站(http://www.wendyshijia.com),遂一时引起众狼骚动,里面的设计和创意都教人赞叹,如此简历让人大呼过瘾,同时作为前端开发工作的一员倍感压...

_EKC
2012/10/25
0
0
强大的矢量图形库:Raphael JS 中文帮助文档及教程

Raphael 是一个用于在网页中绘制矢量图形的 Javascript 库。它使用 SVG W3C 推荐标准和 VML 作为创建图形的基础,你可以通过 JavaScript 操作 DOM 来轻松创建出各种复杂的柱状图、饼图、曲线...

李朝强
2013/10/24
0
1
GBin1分享使用Raphaël类库实现的超酷动画技能图表

发布时间:2011/08/09 编译:Terry li - GBin1.com 原文:tympanus.net 在这篇文章中GBin1将介绍如何使用Raphaël这个js类库构建图表。Raphaël是一个非常小的js类库用于构建丰富的矢量图形。...

gbin1
2011/08/09
893
0
给开发者提供的 35 款 JavaScript 图形图表库

图表是数据图形化的表示,也就是“通过形象的图表来展示数据,比如条形图,折线图,饼图”。几乎每个开发或者项目管理团队都需要图表或者图形来简化理解,可视化复杂的数据和 web 应用工作流...

oschina
2014/02/24
56K
13

没有更多内容

加载失败,请刷新页面

加载更多

Confluence 6 快捷键

快捷键图标。 官方的下载地址为:https://atlassianblog.wpengine.com/wp-content/uploads/2018/01/keyboard-shortcuts-infographics.pdf...

honeymose
今天
2
0
Apache限定目录解析PHP,限制user_agent,PHP相关的配置

Apache限定目录解析PHP 配置前访问upload/index.php [root@test-a ~]# curl -x192.168.77.139:80 'www.test.com/upload/index.php'This is upload diretory 配置,/usr/local/apache2.4/......

野雪球
今天
3
0
java.util.Concurrent.Exchanger源码

类图 源码: package java.util.concurrent;import java.util.concurrent.atomic.AtomicInteger;import java.util.concurrent.atomic.AtomicReference;import java.util.concurrent......

狼王黄师傅
今天
6
0
Kubernetes里的secret最基本的用法

Secret解决了密码、token、密钥等敏感数据的配置问题,使用Secret可以避免把这些敏感数据以明文的形式暴露到镜像或者Pod Spec中。 Secret可以以Volume或者环境变量的方式使用。 使用如下命令...

JerryWang_SAP
昨天
5
0
2018-11-20学习笔记

1. python数据类型: 给变量赋值什么样的值,变量就是什么样的类型 给变量赋值整数,变量就是整数类型 给变量赋值字符串,变量就是字符串类型 123 和“123”一样吗? 在python中 单引号 与双...

laoba
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部