html5 canvas+js鼠标拖动喷字笔刷特效

html5 canvas+js鼠标拖动喷字笔刷特效

添加时间:2021-02-26 05:39:08
站长推荐丨赞助论坛,可获取海量资源终身免费下载权限奥!
举报 举报
收藏
预览
附件 附件
  • 模板类型模板类型:canvas
  • 模板颜色模板颜色:初级
  • 下载积分下载积分:28 米粒
  • 下载权限下载权限:

    赞助会员

一款非常有创意的html5 canvas+js鼠标拖动喷字笔刷特效,鼠标拖动喷出中文字符进行绘图,文字颜色随机,文字的大小跟拖动的速度有关,拖动速度越快则越大。
html5 canvas+js鼠标拖动喷字笔刷特效
分类:文字特效 > canvas 难易:初级

js代码

<script type="text/javascript">
var Xin = (function(){
	var canvas,ctx,W,H,fontsize,texts,isMouseDown,mouse,position,pos;
	function init(){
		canvas = document.createElement("canvas");
		ctx = canvas.getContext("2d");
		canvas.width = W = window.innerWidth;
		canvas.height = H = window.innerHeight;
		document.body.appendChild(canvas);
		fontsize = 3; //最小字号
		texts = '富强、民主、文明、和谐、自由、平等、公正、法治、爱国、敬业、诚信、友善、';
		isMouseDown = false;
		mouse = {x : 0, y : 0 };
		position = {x : 0, y : 0 };
		pos = 0;
		bindEvents();
	}
	function bindEvents(){
		window.onmousedown = handleMouseDown;
		window.onmousemove = handleMouseMove;
		window.onmouseup = handleMouseUp;
		window.onmouseout = handleMouseUp;
		window.onresize = handleResize;
	}
	function handleResize(){
		canvas.width = window.innerWidth;
		canvas.height = window.innerHeight;
	}
	function handleMouseDown(){
		isMouseDown = true;
		position.x = event.pageX;
		position.y = event.pageY;
	}
	function handleMouseMove(){
		if(isMouseDown){
			mouse.x  = event.pageX;
			mouse.y  = event.pageY;
			var d = caculateLength(mouse,position),
				fontSize = fontsize + d /2, //计算在不同鼠标速度下的文字字号
				text = texts[pos],
				stepSize = textWidth(ctx,fontSize,text); //计算位置的宽度
			if(d>stepSize){
				//计算偏离角度
				var angle = Math.atan2(mouse.y-position.y,mouse.x-position.x);
				//绘制文字
				ctx.font = fontSize + "px Arial";
				ctx.fillStyle = randC();
				ctx.save();
				ctx.translate(position.x,position.y);
				ctx.rotate(angle);
				ctx.fillText(text,0,0);
				ctx.restore();
				pos++;
				if(pos==texts.length){
					pos = 0;
				}
				//更新位置
				position.x += stepSize * Math.cos(angle);
				position.y += stepSize * Math.sin(angle);
			}
		}
	}
	function handleMouseUp(){
		isMouseDown = false;
	}
	function caculateLength(p1,p2){
		return Math.sqrt(Math.pow(p2.x-p1.x,2)+Math.pow(p2.y-p1.y,2));
	}
	function textWidth(ctx,fontSize,text){
		ctx.font = fontSize + "px Arial";
		if(ctx.fillText){
			return ctx.measureText(text).width;
		}else if(ctx.mozDrawText){
			return ctx.mozMeasureText(text);
		}
	}
	function randC(){
		return 'rgb(' + (~~(Math.random()*255)) + "," + (~~(Math.random()*255)) + "," + (~~(Math.random()*255)) + ")";
	}
	return { init : init }
})();
Xin.init();
</script>
相关内容推荐
资源求助发帖
查看更多发帖

*

回帖描述:

*

链接类型:

*

下载链接:

密码:
发帖规则:回帖内容为会员之间的私信,普通网友无法查看。
免责声明:回帖中提供的链接内容仅供会员之间学习参考使用,获取内容后请在法律法规范围内使用。回帖提供的内容应符合法律法规要求,不得违反法律法律的要求。
站点权责:回帖内容如违反法律法规,站点有权封停账号使用权利。对用户举报的内容,站点有责任及时删除违规内容。
热点内容推荐
标题:html5 canvas+js鼠标拖动喷字笔刷特效

*

描述:
平均回复时间:3-10分钟
规则介绍:悬赏寻求论坛网友分享资源,站点对分享内容的准确性,合法性,版权等没有足够的监管能力。如果您发现资源不正确,无法使用,不符合法律法律等情况,您可以直接举报资源。站长将尽快核实您的举报,并根据情况,采取封号,退换米粒等处理。

*

回帖描述:

*

链接类型:

*

阅读权限:

*

下载链接:

密码:
发帖规则:回帖内容为会员之间的私信,普通网友无法查看。
免责声明:回帖中提供的链接内容仅供会员之间学习参考使用,获取内容后请在法律法规范围内使用。回帖提供的内容应符合法律法规要求,不得违反法律法律的要求。
站点权责:回帖内容如违反法律法规,站点有权封停账号使用权利。对用户举报的内容,站点有责任及时删除违规内容。
  • 背景波浪
  • 背景波浪
  • 波浪
  • 波浪
客服
在线咨询
周一 至 周日 9:00 ~ 22:00
QQ:1326974360
微信:juyoubuluo6688
客服热线
18205485173
工作日 9:00 ~ 18:00
微信扫码咨询
客户服务
欢迎咨询服务
咨询量较多时,请耐心等待
社群

关注公众号

获取更多资讯

扫码进群(QQ)

与更多大牛交流沟通

0.262326s