iOS与android坐标映射不一致问题

iOS与android坐标映射不一致问题

背景

为什么同一份着色器代码、同样的cvmat数据,Android和iOS两个平台处理之后会得到不一样的结果呢?

这主要是因为iOS和Android使用的渲染图形库不一样,iOS使用的是Metal,而Android使用的是OpenGL ES,而两个图形库的纹理坐标系又不一样:

OpenGL 纹理坐标系(原点在左下角):

Metal/Vulkan 纹理坐标系(原点在左上角):

如果细分着色器中的工作流程,还可以分为两步:

  1. 将cvmat映射到纹理上,这一步要求cvmat和纹理的方向一致;
  2. 将映射后的纹理从片段着色器中输出到渲染管线上,这一步要求cvmat和OpenGL(Android上)/Metal(iOS上)纹理坐标系方向一致。

将着色器中的工作流程与两条线索相结合,可以得到:

  1. 将cvmat与纹理相映射之前,需要对被标准化过的纹理进行一次上下颠倒,以达到纹理坐标系原点在左上角(和cvmat的坐标系一致)的目的。
  2. 将纹理输出到管线上之前:
  3. 在iOS平台上,由于 Metal 纹理坐标系原点就在左上角,所以不需要对上下颠倒过一次的纹理进行二次处理;
  4. 在Android平台上,由于OpenGL 纹理坐标系原点在左下角,而经过第一步颠倒的纹理其原点在左上角,因此需要第二次上下颠倒以同步原点。

综合一下,简单来讲:

  1. 将cvmat与纹理相映射之前,iOS和Android两个平台都需要对纹理进行一次上下颠倒;
  2. 将纹理输出到管线上之前,只有Android需要对纹理进行一次上下颠倒。
相关推荐
I烟雨云渊T20 分钟前
iOS Runtime与RunLoop的对比和使用
ios
掘金-我是哪吒22 分钟前
分布式微服务系统架构第138集:打包发布全流程(iOS + Android)
android·微服务·云原生·架构
奔跑吧 android1 小时前
【android bluetooth 协议分析 01】【HCI 层介绍 9】【ReadLocalSupportedCommands命令介绍】
android·bluetooth·bt·aosp13·hcicmd·bt5.3
小邓是个人才呀2 小时前
第二章:Android常用UI控件
android·java·ui
许三多20207 小时前
Android studio Could not move temporary workspace
android·ide·android studio·workspace
王江奎8 小时前
FFmpeg中使用Android Content协议打开文件设备
android·ffmpeg
YJlio8 小时前
iOS 15.4.1 TrollStore(巨魔商店)安装教程详解:第二篇
macos·ios·cocoa
清霜之辰8 小时前
安卓开发用到的设计模式(1)创建型模式
android·设计模式·创建型模式
隐-梵9 小时前
面向GIS的Android studio移动开发(二)--在地图上绘制电子围栏
android·ide·android studio
末央&10 小时前
【Linux】进程状态
android·linux·运维