视口坐标转换成Canvas下本地坐标与shader显示在3D物体前

2024-03-14 18:20

本文主要是介绍视口坐标转换成Canvas下本地坐标与shader显示在3D物体前,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

     shader显示在3D物体前,先转化成视口坐标

  public virtual void SetESignPos()
        {
            float x = 0;

            float y = 0;

            int v = PlayerPrefsTool.GetSpecialScreen(-1);

            if (EScreenCamera != null)
            {
                Vector3 viewPoint=EScreenCamera.WorldToViewportPoint(CurENeedShowPosition);

                Logger.Log($"SetESignPos viewPoint:{viewPoint},{viewPoint.x*Screen.width},{viewPoint.y*Screen.height}");

                x = viewPoint.x * Screen.width;

                y = viewPoint.y * Screen.height;
            }
            else
            {
                Vector2 screenPos = RectTransformUtility.WorldToScreenPoint(mE_f.canvas.worldCamera, CurENeedShowPosition);

                x = screenPos.x;

                y = screenPos.y;
            }

            if (v == -1)//正常屏幕
            {
                y = Screen.height - y;
            }

            mESignMaterial.SetVector("_LP1", new Vector4(x, y, mESignMaterialVector4.z, mESignMaterialVector4.w));
        }

视口坐标转换成Canvas下本地坐标

using UnityEngine;
using UnityEngine.UI;

public class ViewportToCanvasCoordinates : MonoBehaviour
{
    public RectTransform canvasRect;

    void Update()
    {
        // 设置一个示例的视口坐标
        Vector3 viewportPoint = new Vector3(0.5f, 0.5f, 0);

        // 获取主摄像机
        Camera mainCamera = Camera.main;

        if (mainCamera != null)
        {
            // 使用主摄像机的方法将视口坐标转换为屏幕坐标
            Vector3 screenPoint = mainCamera.ViewportToScreenPoint(viewportPoint);

            // 将屏幕坐标转换为 UI 中的 Canvas 坐标
            Vector2 localPoint;
            RectTransformUtility.ScreenPointToLocalPointInRectangle(canvasRect, screenPoint, mainCamera, out localPoint);

            // 打印 UI 中的 Canvas 坐标
            Debug.Log("UI Canvas Local Point: " + localPoint);
        }
    }
}
 

这篇关于视口坐标转换成Canvas下本地坐标与shader显示在3D物体前的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/809307

相关文章

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放

Git打标签从本地创建到远端推送的详细流程

《Git打标签从本地创建到远端推送的详细流程》在软件开发中,Git标签(Tag)是为发布版本、标记里程碑量身定制的“快照锚点”,它能永久记录项目历史中的关键节点,然而,仅创建本地标签往往不够,如何将其... 目录一、标签的两种“形态”二、本地创建与查看1. 打附注标http://www.chinasem.cn

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

Java实现本地缓存的四种方法实现与对比

《Java实现本地缓存的四种方法实现与对比》本地缓存的优点就是速度非常快,没有网络消耗,本地缓存比如caffine,guavacache这些都是比较常用的,下面我们来看看这四种缓存的具体实现吧... 目录1、HashMap2、Guava Cache3、Caffeine4、Encache本地缓存比如 caff

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤