Pixi.js学习 (四)鼠标跟随、元素组合与图片位控

目录

一、鼠标移动跟随

1.1 获取鼠标坐标

1.2 鼠标跟随

二、锚点、元素组合

2.1 锚点

2.2 元素组合

三、图片图层

四、实战

例题一:完成合金弹头人物交互

例题二:反恐重击瞄准和弹痕

例题一代码:

例题二代码:

总结


前言

为了提高作者的代码编辑水品,作者在使用博客的时候使用的集成工具为 HBuilderX。

下文所有截图使用此集成工具,读者随意。

此系列文章需要:HTML ,JavaScript 基础知识

操作系统:

版本    Windows 11 家庭中文版
版本    23H2
安装日期    ‎2024/‎5/‎28
操作系统版本    22631.3593
体验    Windows Feature Experience Pack 1000.22700.1003.0


一、鼠标移动跟随

1.1 获取鼠标坐标

程序会记录鼠标在元素中触发时间的坐标位置(x,y)[监听器引入] 我们可以通过在自定义函数中设置参数获取触发事件时的(x,y)

getlocalPosition()

获取某个元素鼠标事件的触发位置

实例:

function move(event){
    var pos = event.data.getLocalPosition(app.stage);
    var x = pos.x ;
    var y = pos.y ;
    console.log("当前水平坐标为:"+x+" "+"当前垂直坐标为:"+y)
    }

注释:

event:触发的事件

data:数据

getlocalPosition():获取某个元素鼠标事件的触发位置

var x = pos.x ;获取事件触发时的x坐标

var y = pos.y ;获取事件触发时的y坐标

任意一种鼠标事件,都可以通过以上案例的方式获取到鼠标坐标。

1.2 鼠标跟随

鼠标跟随就是控制元素,可以跟着鼠标指针一起移动。

思路:

鼠标移动触发mousemove事件

在事件中通过event.data.getLocalposition(app.stage)获取当前鼠标坐标(x,y)

把当前获取到的(x,y)设置为图片元素定位坐标

代码:

<script type="text/javascript">
			
			var app=new PIXI.Application(512,768);
			
			document.body.appendChild(app.view);																							

			function add(img,x,y){
				//创建图片元素
				var a=new PIXI.Sprite.fromImage(img);
				//将元素添加到页面中
				app.stage.addChild(a);
				//调整位置
				a.x=x
				a.y=y 
				
				//对当前元素直接开启监听
				a.interactive=true;
				
				return a;
			}

			//添加背景
			var bg = add("img/bg_01.png",0,0); 
			//添加飞机
			var plane = add("img/plane_blue_01.png", 100, 300);

			//设置飞机锚点
			plane.anchor.set(0.5);
			
			var zuobiao=new PIXI.Text("坐标:");
			app.stage.addChild(zuobiao);
			zuobiao.style.fill="#000000";
			zuobiao.x=50;
			zuobiao.y=40;

			//为背景设置鼠标移动事件绑定
			bg.on("mousemove",mousemove);
			//提供函数
			function mousemove(event){

				//获取鼠标触发时的坐标
				var pos=event.data.getLocalPosition(app.stage)
				//飞机元素鼠标跟随
				plane.x=pos.x
				plane.y=pos.y

				//将坐标显示到页面上			
				zuobiao.text = "坐标 X:"+pos.x+"\n"+"坐标 Y:" + pos.y
				

			}

			
			
			
			
			
			
			
					
					
					
</script>

运行效果:

其中:zuobiao.text = "坐标 X:"+pos.x+"\n"+"坐标 Y:" + pos.y

这句代码使用了字符拼接,将" "内的字符用 + 和获取到的字符进行了拼接

"\n" 是 转义字符 表示换行

我们可以看到这样坐标显示的总有一大串小数,我们不需要那么精确,小数太多反而影响观看,因此可以使用取整。

取整常用有方法:

//向上取整
Math.ceil(参数)

//向下取整
Math.floor()

//忽略小数部分
parseInt(参数)

然后我们对原代码进行编辑修改。

修改函数内的代码为:

            //提供函数
			function mousemove(event){

				//获取鼠标触发时的坐标
				var pos=event.data.getLocalPosition(app.stage)
				//飞机元素鼠标跟随
				plane.x=pos.x
				plane.y=pos.y
                
                //对获取到的坐标进行取整
				var zx=Math.ceil(pos.x)
				var zy=Math.ceil(pos.y)

				//将坐标显示到页面上			
				zuobiao.text = "坐标 X:"+zx+"\n"+"坐标 Y:" + zy
				

			}

我们可以看到此时的坐标均为整数:

此时坐标显示便于观看。


二、锚点、元素组合

2.1 锚点

元素的锚点,也可以叫做定位点,指元素以x,y哪个点来对齐该坐标。

语法格式:

元素.anchor.set(值,值)

实例:

plane.anchor.set(1,1);

2.2 元素组合

将独立的多个元素合并到一起,视为一个整体,便于程序对多个元素的统一处理。

			//将元素添加到另一个元素中
			var liaoji1 = add("img/liaoji1.png", -120, 10)
			var liaoji2 = add("img/liaoji2.png", 60, 10)
			//将元素添加到舞台中
			plane.addChild(liaoji1,liaoji2);

liaoji1:添加元素定义的名称

add("img/liaoji1.png", -120, 10):添加元素的本地路径

-120,10:添加元素位于被添加元素锚点的坐标

注意:辅元素添加到主元素中时,辅元素的默认起始位置等于主元素的锚点 当为辅元素设置位置时(x,y),x与y表示的是辅元素与主元素之间的距离。

代码:

		<script type="text/javascript">
			
			var app=new PIXI.Application(500,700);
			
			document.body.appendChild(app.view);																							
			function add(img,x,y){
				//创建图片元素
				var a=new PIXI.Sprite.fromImage(img);
				//将元素添加到页面中
				app.stage.addChild(a);
				//调整位置
				a.x=x
				a.y=y 
				
				//对当前元素直接开启监听
				a.interactive=true;
				
				return a;
			}


			var bg = add("img/bg_01.png",0,0); 
			var plane = add("img/plane_blue_01.png", 250, 350);
			
			plane.anchor.set(0.5,0.5);
			


			//为个元素绑定移动事件
			bg.on("mousemove",planemove);
			
			function planemove(event){
				var pos=event.data.getLocalPosition(app.stage)
				
				plane.x=pos.x;
				plane.y=pos.y;
				
			}
			
			
			//将元素添加到另一个元素中
			var liaoji1 = add("img/liaoji1.png", -120, 10)
			var liaoji2 = add("img/liaoji2.png", 60, 10)
			//将元素添加到舞台中
			plane.addChild(liaoji1,liaoji2);
			
			
								
		</script>

运行效果:

此时小飞机跟随大飞机的移动,它和大飞机成为一个整体。


三、图片图层

图片图层:图片在应用窗口的层级

默认图层效果:先插入的元素低于后插入的元素(后插入的元素会遮盖先插入的元素)

合并元素图层效果:辅元素会与主元素图层一致并将主元素向下压一级(辅元素会遮盖主元素) 原来遮盖主元素的其他元素,现在将同时遮盖主元素与辅元素

		<script type="text/javascript">
			

		
			var app = new PIXI.Application(1008,640);
			document.body.appendChild( app.view );
			//第一个元素,层级最低的元素 主元素
			var bg = new PIXI.Sprite.fromImage("img/bg1.png");
			bg.x = 0;
			bg.y = 0;
			app.stage.addChild(bg);
			//第二个元素 此图层高于背景
			var js = new PIXI.Sprite.fromImage("img/js1.png");
			js.x = 600;
			js.y = 400;
			app.stage.addChild(js);

					
					
		</script>

效果展示:

注意:当两个元素合并时,辅元素的默认宽高会受到主元素的影响,如果不希望辅元素受到影响,需要 为辅元素单独设置宽高。

四、实战

例题一:完成合金弹头人物交互

要求:

  • 创建应用,宽600,高380.
  • 左右键,人物移动转身。(人物上半身,下半身应该是主辅元素的关系)

结果图:

例题二:反恐重击瞄准和弹痕

要求:

  • 创建应用,宽800,高600.
  • 瞄准镜瞄准移动显示坐标
  • 按下鼠标留下弹坑

示范图:

例题一代码:

		<script type="text/javascript">
			
			var app=new PIXI.Application(600,380);
			
			document.body.appendChild(app.view);																							
			function add(img,x,y){
				//创建图片元素
				var a=new PIXI.Sprite.fromImage(img);
				//将元素添加到页面中
				app.stage.addChild(a);
				//调整位置
				a.x=x
				a.y=y 
				
				//对当前元素直接开启监听
				a.interactive=true;
				
				return a;
			}


			var bg = add("img/bg.png",0,0); 
			var shen = add("img/image1390.png", 300, 250);
			var zuo=add("img/zuo.png", 20, 250);
			var you=add("img/you.png", 90, 250);
			//
			shen.anchor.set(0.5);
			//初始为左
			shen.scale.x = 1
			zuo.on("click",fzuo);
			you.on("click",fyou);


			function fzuo(){
				if(shen.scale.x == 1){
				    shen.x-=20;
				}else{
					shen.scale.x = 1
					// shen.x+=20;
				}	
								
			}
			function fyou(){
				if(shen.scale.x == -1){
				    shen.x+=20;
				}else{
					shen.scale.x = -1
					// shen.x+=20;
				}	

			}


			
			
			//将元素添加到另一个元素中
			var jiao = add("img/image1334.png", 0,18 )
			shen.addChild(jiao);
			//将元素添加到舞台中
			

					
		</script>

运行效果:

例题二代码:

		<script type="text/javascript">
			
			var app=new PIXI.Application(800,600);
			
			document.body.appendChild(app.view);																							

			function add(img,x,y){
				//创建图片元素
				var a=new PIXI.Sprite.fromImage(img);
				//将元素添加到页面中
				app.stage.addChild(a);
				//调整位置
				a.x=x;
				a.y=y;
				
				//对当前元素直接开启监听
				a.interactive=true;
				
				return a;
			}


			var bg = add("img/bg.jpg",0,0); 
			var miao = add("img/miao.png",0,0);
			
			//设置瞄准锚点
			miao.anchor.set(0.5);
			
			var zuobiao=new PIXI.Text("坐标:");
			app.stage.addChild(zuobiao);
			zuobiao.style.fill="000000";
			zuobiao.x=30;
			zuobiao.y=500;


			
			bg.on("mousemove",mousemove);
			miao.on("click",danmove);
			
			function danmove(event){
				var pos=event.data.getLocalPosition(app.stage)
				add("img/dan.png",pos.x,pos.y);
			}



			//瞄准镜瞄准移动 添加坐标函数
			function mousemove(event){
				var pos=event.data.getLocalPosition(app.stage)	
				miao.x=pos.x;
				miao.y=pos.y;

				//将坐标显示到页面上
				zuobiao.text="X:"+Math.ceil(pos.x)+"\n"+"Y:"+Math.ceil(pos.y);

				
			}

			
			
						
					
		</script>

运行结果:

本文所用到的图片以及项目源码:

https://download.csdn.net/download/qq_56376552/89412764


总结

本文 鼠标跟随、元素组合与图片位控 就此结束,

如有错误或者网址更新,步骤更改,代码错误欢迎私信作者进行更正,

感谢您的观看。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/700872.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【会议征稿,五大海内外高校支持】第四届经济发展与商业文化国际学术会议(ICEDBC2024,6月21-23)

第四届经济发展与商业文化国际学术会议&#xff08;ICEDBC2024&#xff09;将于2024年6月21-23日在中国大连隆重召开。会议主要围绕“经济发展”“商业文化”等研究领域展开讨论。 旨在为经济&#xff0c;商业的专家学者及企业发展人提供一个分享研究成果、讨论存在的问题与挑战…

调整SinoDB数据库日志模式

在数据库上线后&#xff0c;可能需要变更数据库的日志模式&#xff0c;这可能是由于业务变更或性能调整等原因引起的。数据库日志模式的变更可能涉及单一实例环境或高可用集群环境。本文将介绍如何调整SinoDB数据库的日志模式。 1、 停止应用程序 在修改数据库日志模式之前&am…

Spring 中使用MyBatis

一、Mybatis 的作用 1、MyBatis&#xff08;前身为iBatis&#xff09;是一个开源的Java持久层框架&#xff0c;它主要用于与数据库交互&#xff0c;帮助开发者更轻松地进行数据库操作。 持久层&#xff1a;指的是就是数据访问层(dao)&#xff0c;是用来操作数据库的。 2、MyB…

【BIM+GIS】Supermap优化BIM模型

文章目录 一、生成缓存二、实例化一、生成缓存 第一步:导出Revit模型 第二步:加载模型 第三步:生成缓存 第四步:添加到场景 二、实例化 实例化技术适用于重复模型较多的情况,可以实现对相同的几何模型只绘制一次,降低了显卡等硬件设备的压力。例如,一幢房屋中存在大量…

C++ day6 练习

#include <iostream>using namespace std;class Animal { private:string name; public:Animal(){}Animal(string name):name(name){}virtual void perform(){cout << "我是" << name <<endl;} };class Lion:public Animal { private:string…

Deploy Kafka for Centos 7

应用介绍 Kafka是由Apache软件基金会开发的一个开源流处理平台&#xff0c;由Scala和Java编写&#xff0c;用于处理消费者在网站中的所有动作流数据。 Kafka是一种高吞吐量的分布式发布订阅消息系统&#xff0c;它可以处理消费者在网站中的所有动作流数据&#xff0c;这些数据…

filezilla-server 1.8.1 设置

filezilla-server 1.8.1 设置&#xff1a; 1. 2. 3. 4. 其他不用配置&#xff0c; 5. 6. 7. 8. 9. 如果外网连不上 filezilla-server 提示无法连接到服务器&#xff0c; 多半是 filezilla-server 所在的电脑没有通过防火墙允许&#xff0c;打开 Windows defender 防…

最短路径Dijkstra算法详解

目录 最短距离问题 最短路径问题 进阶--标尺增多 升级方法 例题应用 最短距离问题 Dijkstra算法的策略&#xff1a; 设置集合S存放已被访问的顶点&#xff0c;然后执行n次下面的两个步骤&#xff08;n为顶点个数&#xff09;&#xff1a; &#xff08;1&#xff09;每次…

c++中string用法详解

目录 二、案例需求 三、案例实现 1.首先获取strData中的角色数量 2.创造结构体数组&#xff0c;定义两个索引值 3.循环遍历对结构体User中的Id和Exp进行赋值 4.对结构体数组userArr进行排序 5.展示结果以及最终代码 ​四、最后 一、前言 在C中&#xff0c;std::string …

webshell三巨头 综合分析(蚁剑,冰蝎,哥斯拉)

考点: 蚁剑,冰蝎,哥斯拉流量解密 存在3个shell 过滤器 http.request.full_uri contains "shell1.php" or http.response_for.uri contains "shell1.php" POST请求存在明文传输 ant 一般蚁剑执行命令 用垃圾字符在最开头填充 去掉垃圾字符直到可以正常bas…

STM32MP135裸机编程:配置RCC,修改主频到1GHz

0 工具准备 STM32CubeMX v6.11.1 STM32CubeIDE v1.15 STM32CubeProgrammer v2.16.0 STM32MP13xx参考手册 STM32MP13勘误手册 STM32MP135AD数据手册 正点原子stm32MP135开发板 1 确认时钟源 本例使用的时钟源均由外部晶振提供&#xff0c;分别是24MHz的HSE、32.768KHz的LSE。原…

服务器制作RAID磁盘阵列并管理

1. 规划节点 主机规划 IP主机名节点192.168.100.10localhost控制节点 2. 基础准备 使用VMWare Workstation软件安装CentOS 7.2操作系统&#xff0c;镜像使用提供的 CentOS-7-x86_64-DVD-1511.iso&#xff0c;并添加4块20 GB硬盘。YUM源使用提供的 mdadm_yum文件夹。 1. 创…

R可视化:ggpubr包学习

欢迎大家关注全网生信学习者系列&#xff1a; WX公zhong号&#xff1a;生信学习者 Xiao hong书&#xff1a;生信学习者 知hu&#xff1a;生信学习者 CDSN&#xff1a;生信学习者2 介绍 ggpubr是我经常会用到的R包&#xff0c;它傻瓜式的画图方式对很多初次接触R绘图的人来…

Thinkphp一文鸡富贵鸡玫瑰庄园富农场仿皮皮果理财农场源码

Thinkphp一文鸡富贵鸡玫瑰庄园富农场仿皮皮果理财农场源码&#xff0c;喜欢的朋友可以下载研究 一文鸡富贵鸡玫瑰庄园富农场仿皮皮果理财农场源码

什么是自适应滤波器?

一、自适应滤波器 自适应滤波器是一种能够自动调整其滤波参数以匹配输入信号特性变化的滤波器&#xff0c;主要用于信号处理中选择性地通过特定频率范围内的信号&#xff0c;同时抑制其他频率成分。自适应滤波器主要有几种&#xff1a; LMS (Least Mean Squares) 自适应滤波器…

pytest+requests+allure自动化测试接入Jenkins学习

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 最近在这整理知识&#xff0c;发现在pytest的知识文档缺少系统性&#xff0c;这里整理一下&…

react 搭建简单的后台管理系统

1.分析后台组成 后台基本组成是由菜单、头部、内容区域组成 2 后台具体实现 2.1 整体页面布局 页面整体布局为侧边栏(CommonAside)、头部(CommonHeader)、标签区域(CommonTag)、内容区域(Content)四部分组成&#xff0c;展开和收起功能是把展开和收起的状态&#xff0c;用一个…

Unity基础(三)3D场景搭建

目录 简介: 一.下载新手资源 二.创建基本地形 三.添加场景细节 四,添加水 五,其他 六. 总结 简介: 在 Unity 中进行 3D 场景搭建是创建富有立体感和真实感的虚拟环境的关键步骤。 首先&#xff0c;需要导入各种 3D 模型资源&#xff0c;如建筑物、角色、道具等。这些模…

Java——IO流(一)-(3/8):File案例练习-文件遍历,文件搜索,删除非空文件夹,啤酒问题(需求分析、问题解决、运行结果)

目录 文件遍历&#xff08;遍历所有文件及文件夹&#xff09; 需求分析 问题解决 运行结果 文件搜索 需求分析 问题解决 运行结果 删除非空文件夹 啤酒问题&#xff08;递归案例&#xff09; 文件遍历&#xff08;遍历所有文件及文件夹&#xff09; 需求分析 需求&am…

【全开源】医护上门系统小程序APP公众号h5源码

医护上门系统&#xff1a;健康守护&#xff0c;就在您身边 &#x1f6aa;引言&#xff1a;开启全新的医护模式 在快节奏的现代生活中&#xff0c;健康问题往往成为我们关注的焦点。而“医护上门系统”正是为了满足这一需求&#xff0c;将专业的医疗服务送到您的家中。这一创新…