Cocos_鼠标滚轮放缩地图

embedded/2024/10/11 1:01:55/

文章目录

  • 前言
  • 一、环境
  • 二、版本一_code
    • 2.分析
      • 属性
      • 方法
      • 详细分析
        • 详细分析onLoad()
        • onMouseWheel(event)详细分析
  • 总结


前言

学习笔记,请多多斧正。


一、环境

在这里插入图片描述
在这里插入图片描述
通过精灵rect放置脚本实现鼠标滚轮放缩地图。

二、版本一_code

import { _decorator, Component, Node } from 'cc';
const { ccclass, property } = _decorator;@ccclass('MapZoom')
export class MapZoom extends Component {@property(Node)mainMapNode = null; // 大地图节点@property(Node)miniMapNode = null; // 小地图节点(不会被缩放)@propertyscaleFactor = 0.1; // 缩放因子@propertyminScale = 0.5; // 最小缩放比@propertymaxScale = 3.0; // 最大缩放比onLoad() {// 绑定鼠标滚轮事件this.node.on(Node.EventType.MOUSE_WHEEL, this.onMouseWheel, this);}onMouseWheel(event) {// 获取当前大地图缩放比例let currentScale = this.mainMapNode.scale.x;// 根据滚动方向调整缩放比例if (event.getScrollY() > 0) {// 向上滚动,放大currentScale += this.scaleFactor;} else {// 向下滚动,缩小currentScale -= this.scaleFactor;}// 限制缩放范围currentScale = Math.max(this.minScale, Math.min(currentScale, this.maxScale));// 应用新的缩放值,只对大地图进行设置this.mainMapNode.setScale(currentScale, currentScale, currentScale);// 小地图保持原样,不做任何修改}
}

2.分析

@ccclass('MapZoom'): 这是一个装饰器,用于定义一个新的 Cocos Creator 组件类,名为 MapZoom。
extends Component: MapZoom 类继承自 Cocos Creator 的 Component 基类,意味着它可以作为场景中的一个组件使用。

属性

  • mainMapNode:
    类型:Node
    描述:代表大地图的节点。这个节点会根据用户的鼠标滚轮输入进行缩放。
  • miniMapNode:
    类型:Node
    描述:表示小地图的节点。小地图不会受到缩放影响,因此在鼠标滚动时不进行修改。
  • scaleFactor:
    类型:number
    描述:每次鼠标滚轮滚动时,缩放的增量。默认值为 0.1。
  • minScale:
    类型:number
    描述:大地图可缩放的最小比例。默认值为 0.5。
  • maxScale:
    类型:number
    描述:大地图可缩放的最大比例。默认值为 3.0。

方法

onLoad()

  • 在组件加载时自动调用该方法。它主要用于设置事件监听器。
  • this.node.on(Node.EventType.MOUSE_WHEEL, this.onMouseWheel, this): 绑定鼠标滚轮事件,当用户滚动鼠标时,会触发 onMouseWheel 方法。

onMouseWheel(event)

  • 这是处理鼠标滚轮事件的主要方法。
  • 获取当前缩放比例:使用 this.mainMapNode.scale.x 获取当前大地图的缩放值。
  • 缩放调整:
    • 如果滚轮向上滚动 (event.getScrollY() > 0),则增加缩放值。
    • 如果滚轮向下滚动,则减少缩放值。
  • 限制缩放范围:
    • 使用 Math.max()Math.min() 来确保缩放值在设定的最小和最大范围内。
  • 应用缩放:
    • 调用 this.mainMapNode.setScale(currentScale, currentScale, currentScale) 来更新大地图的缩放值。
    • 小地图保持不变,不做处理。

详细分析

详细分析onLoad()
onLoad() {// 绑定鼠标滚轮事件this.node.on(Node.EventType.MOUSE_WHEEL, this.onMouseWheel, this);
}
  1. 生命周期方法
    onLoad():
    这是 Cocos Creator 组件的一部分,表示当组件被实例化并添加到场景中时调用的方法。在这个阶段,所有的属性都已初始化,并且可以访问组件的节点和其他资源。
  2. 事件绑定
  • this.node.on(...):
    this.node 是当前组件所附加的节点(Node)。on 方法用于注册事件监听器。
  • Node.EventType.MOUSE_WHEEL:
    这是一个预定义的事件类型,表示鼠标滚轮事件。它会在用户滚动鼠标滚轮时触发。
  • this.onMouseWheel:
    这是事件处理函数的引用。当鼠标滚轮事件被触发时,Cocos Creator 会调用这个方法来处理事件。在本例中,当用户滚动鼠标时,将会执行 onMouseWheel 方法。
  • this:
    这是上下文参数,用于指定 onMouseWheel 方法中的 this 引用。通过传入 this,确保在 onMouseWheel 方法被调用时,this 指向当前的 MapZoom 实例,而不是可能的其他对象(如事件的源对象)。
onMouseWheel(event)详细分析
onMouseWheel(event) {// 获取当前大地图缩放比例let currentScale = this.mainMapNode.scale.x;// 根据滚动方向调整缩放比例if (event.getScrollY() > 0) {// 向上滚动,放大currentScale += this.scaleFactor;} else {// 向下滚动,缩小currentScale -= this.scaleFactor;}// 限制缩放范围currentScale = Math.max(this.minScale, Math.min(currentScale, this.maxScale));// 应用新的缩放值,只对大地图进行设置this.mainMapNode.setScale(currentScale, currentScale, currentScale);// 小地图保持原样,不做任何修改}
}
  1. 获取当前大地图缩放比例
let currentScale = this.mainMapNode.scale.x;
  • this.mainMapNode: 这是一个指向大地图节点的引用。
  • scale.x: 获取大地图当前的缩放比例(通常只需获取 x 轴的缩放比例,因为在2D图形中,通常三个轴的缩放是相同的)。
  1. 根据鼠标滚动方向调整缩放比例
if (event.getScrollY() > 0) {// 向上滚动,放大currentScale += this.scaleFactor;
} else {// 向下滚动,缩小currentScale -= this.scaleFactor;
}
  • event.getScrollY(): 获取鼠标滚轮的滚动值。如果返回值大于0,则表示鼠标向上滚动;如果返回值小于0,则表示向下滚动。
  • this.scaleFactor: 一个预定义的变量,决定每次滚轮操作时缩放的大小。
  1. 限制缩放范围
currentScale = Math.max(this.minScale, Math.min(currentScale, this.maxScale));
  • 使用 setScale() 方法将计算后的 currentScale 应用到大地图节点上,更新其视觉表现。这会影响到渲染和用户看到的地图。

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。


http://www.ppmy.cn/embedded/125637.html

相关文章

《Java程序员面试宝典》——(第二章节)

当前因为经济大环境不好、大厂裁员、就业情况差、企业要求变高、各行各业越来越卷,尤其是程序员,处于这个阶段,感觉特别明显! 对于程序员这个群体来说,java程序员的占比就非常之高,就业市场等于说是千军万…

51单片机的无线通信智能车库门【proteus仿真+程序+报告+原理图+演示视频】

1、主要功能 该系统由AT89C51/STC89C52单片机LCD1602显示模块红外传感器光照传感器时钟模块步进电机蓝牙按键、LED、蜂鸣器等模块构成。适用于智能车库自动门、无线控制车库门等相似项目。 可实现功能: 1、LCD1602实时显示北京时间和自动/手动模式,以及验证是否成…

【线性代数】【第一章】行列式习题

文章目录 一. 重要定理1. 代数余子式2. 主要公式3. 方阵的行列式4. 克拉默法则 三. 典型例题1. 行列式计算1.1. 数字型行列式题型一:代数余子式降阶、拉普拉斯题型二:逐行消元,化为上三角式 1.2.抽象行列式(考察行列式的性质&…

Leetcode203.移除链表元素-Python

题目链接:203. 移除链表元素 - 力扣(LeetCode) 题目描述: 给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val val 的节点,并返回 新的头节点 。 示例 1: 输入&a…

宠物空气净化器哪个牌子吸毛好?希喂、IAM、352真实测评

前段时间忙活了个大工程——热门宠物空气净化器大横评,通过多方位的测试,帮助不少朋友解决了宠物空气净化器的选购难题。 但我们还不局限于此,在从事家电行业这些年间,我们还花费大价钱购置一堆产品实测体验过各类大小家电产品&a…

rocky9 samba共享

1. 安装samba服务,设置开机自启。 2. 创建四个用户user1,user2,sale1,manager,user1,user2属于finance组,sale1属于sales组,manager属于manager组。 3. 建立共享目录/opt/finance_…

springboot中@ConfigurationProperties注解的用法

简介 ConfigurationProperties注解在Spring Boot框架中提供了一种将外部配置(如application.properties或application.yml文件中的属性)绑定到Java对象的便捷方式。以下是ConfigurationProperties注解的详细用法 基本用法 定义配置类 创建一个普通的…

机器学习:关联规则:Apriori算法、FP - Growth算法的原理、应用场景及优缺点介绍

一、关联规则算法概述 关联规则挖掘是数据挖掘中的一个重要任务,用于发现数据集中不同项之间的关联关系。 二、Apriori算法 原理 频繁项集生成:Apriori算法基于一个先验原理,即如果一个项集是频繁的,那么它的所有子集也是频繁的…