当前位置: 首页 > wzjs >正文

商城网站建设可以吗seo关键词优化最多可以添加几个词

商城网站建设可以吗,seo关键词优化最多可以添加几个词,防城港做网站的,网站名字设计在 Unity UI 开发中,有时需要让图标沿着一条道路轨迹移动,比如地图上的车辆行驶动画、导航路径指示等。本文介绍如何基于 UI 图片中的道路线生成曲线,并使用 Slider 控制图标沿轨迹运动,适用于 UI 导航、路径跟随动画等场景。 1. …

在 Unity UI 开发中,有时需要让图标沿着一条道路轨迹移动,比如地图上的车辆行驶动画导航路径指示等。本文介绍如何基于 UI 图片中的道路线生成曲线,并使用 Slider 控制图标沿轨迹运动,适用于 UI 导航、路径跟随动画等场景


1. 功能介绍

  • 基于 UI 图片自动解析道路轨迹,生成 AnimationCurve
  • 使用 Slider 控制图标沿道路移动
  • 适用于 UI 地图、导航路径动画等

最终效果👇

2. 代码实现

2.1 解析道路轨迹,生成曲线路径

思路:

  • 读取 UI 图片 (Image) 的 Sprite,获取 Texture2D
  • 遍历像素点,找到道路轨迹的像素
  • 转换为 UI 坐标,存入 AnimationCurve,用于后续运动计算
using UnityEngine;
using UnityEngine.UI;
using System.Collections.Generic;
using Sirenix.OdinInspector;public class PathGenerator : MonoBehaviour
{public Image roadImage; // 道路线 UI 图片public AnimationCurve pathCurve = new AnimationCurve(); // 道路路径曲线[Button("Generate Path")]public void GeneratePath(){if (roadImage == null || roadImage.sprite == null){Debug.LogError("Road Image or Sprite is not assigned.");return;}Sprite sprite = roadImage.sprite;Texture2D texture = sprite.texture;Rect rect = sprite.rect;List<Vector2> points = new List<Vector2>();// 计算缩放比例RectTransform rectTransform = roadImage.rectTransform;float scaleX = rectTransform.rect.width / rect.width;float scaleY = rectTransform.rect.height / rect.height;// 提取道路轨迹上的点for (int x = 0; x < rect.width; x++){for (int y = 0; y < rect.height; y++){Color pixel = texture.GetPixel((int)rect.x + x, (int)rect.y + y);if (pixel.a > 0.1f) // 透明度判断,找到道路轨迹{Vector2 point = new Vector2((x - rect.width / 2) * scaleX, // UI 坐标转换(y - rect.height / 2) * scaleY);points.Add(point);break;}}}// 生成曲线路径pathCurve = new AnimationCurve();foreach (Vector2 p in points){pathCurve.AddKey(p.x, p.y);}}
}

生成一条与路径相同的Curve,效果如下👇

2.2 让图标沿道路轨迹移动

思路:

  • 监听 Slider 拖动事件,获取 value
  • Slider 值映射到曲线的 X 轴坐标
  • 计算对应 Y 轴坐标,更新图标位置
using Cysharp.Threading.Tasks;
using UnityEngine;
using UnityEngine.UI;public class FollowPath : MonoBehaviour
{public PathGenerator pathGenerator; // 路径生成器public Slider slider; // 控制 CurrentX 的 Sliderasync void Start(){if (slider != null){slider.onValueChanged.AddListener(OnSliderValueChanged);}await UniTask.WaitForFixedUpdate();OnSliderValueChanged(slider.value);}void OnSliderValueChanged(float value){if (pathGenerator == null || pathGenerator.pathCurve.length == 0 || slider == null) return;// 获取路径的X范围float minX = pathGenerator.pathCurve.keys[0].time;float maxX = pathGenerator.pathCurve.keys[pathGenerator.pathCurve.length - 1].time;// 映射 Slider 的值到 CurrentXfloat currentX = Mathf.Lerp(minX, maxX, value);// 获取对应的Y坐标float y = pathGenerator.pathCurve.Evaluate(currentX);// 更新 UI 位置RectTransform rectTransform = GetComponent<RectTransform>();rectTransform.anchoredPosition = new Vector2(0, y + 4);}
}

3. 运行效果

  1. 点击 Generate Path,从 UI 图片解析道路轨迹
  2. 拖动 Slider,图标沿道路轨迹平滑移动
  3. 可用于 UI 导航、路径动画等场景

4. 适用场景

UI 地图导航(如 GPS 轨迹动画)
车辆行驶路径(如小车沿地图行驶)
手绘路径动画(如绘制道路后小车自动行驶)

如果有更好的优化方案,欢迎讨论! 🚀


最后贴上道路线的图片:

http://www.dtcms.com/wzjs/441744.html

相关文章:

  • 慧聪网网址seo咨询师
  • 张家港做网站优化价格搜索词分析工具
  • 网站程序建设百度快照的作用是什么
  • 网站运营 策划 推广 维护谷歌关键词搜索排名
  • 网站建设 微信 app2023年11月新冠高峰
  • 一个阿里云怎么做两个网站管理人员课程培训
  • 做网站怎建立ftp和数据库免费p站推广网站入口
  • 珠海网站推广1688黄页大全进口
  • 自己的网站如何做分销seo关键词排名优化手机
  • 网站 虚拟主机 操作系统广东全网推广
  • 我做的网站手机上不了东莞百度seo哪里强
  • 设计师个人主页汕头seo优化公司
  • 做网站JSP代码山西seo排名
  • 淘客那些网站怎么做的网站建设找哪家公司好
  • 厦门营销网站建设公司新网站百度收录
  • 网站设计多少钱市场价哪个平台做推广效果好
  • 中国建设监理协会网站查询成绩营销方案100例
  • 网站上传不了图片不显示不出来自己如何制作网站
  • 快件网站建设营销案例100例简短
  • 关于工程项目建设的网站站长统计app最新版本2023
  • 怎样做自己的视频网站每天4元代发广告
  • 给网站做外链要注意哪些黑帽seo技巧
  • 做张网站banner多少钱贵阳搜索引擎排名推广
  • 网站开发加盟商怎么做东莞网站建设最牛
  • 如何取一个大气的名字的做网站seo网站优化培训厂家报价
  • 青州哪里做网站成都私人网站制作
  • 中小企业公共服务平台seo视频教程百度云
  • 廊坊建设企业网站学做网站需要学什么
  • 龙岩网站定制长尾关键词在线查询
  • 成都设计公司电话泰安网站优化公司