原文地址:http://www.manew.com/forum.php?mod=viewthread&tid=91191&page=1&authorid=119383
新建一个项目,拖入ARcamera和ImageTarget
data:image/s3,"s3://crabby-images/d21ec/d21ecd3c0785ebf7c9c940b0f292b7095c4991ca" alt=""
data:image/s3,"s3://crabby-images/d34b9/d34b98ed9915a9c21340cc21895cb382aa615362" alt=""
data:image/s3,"s3://crabby-images/cb865/cb865f89247c0cc7bc9821eadc1fa85b224cd79d" alt=""
data:image/s3,"s3://crabby-images/a2ed7/a2ed70618ed5db56d86247d7e26471211f7c05e4" alt=""
data:image/s3,"s3://crabby-images/c3379/c3379c2634103960d02741fdd916b16b4c9a7902" alt=""
data:image/s3,"s3://crabby-images/1920c/1920c7bc32f9efe1b880f01930e015546e1a9fd5" alt=""
data:image/s3,"s3://crabby-images/d570b/d570be9d6f601a1baf804e5421135d9cc7d2bbbe" alt=""
data:image/s3,"s3://crabby-images/f3b48/f3b48594cb8e68c88eade0c72963edca6feabdd8" alt=""
设置两个layer层maliaohe maliao01,panel设置为maliao,马里奥模型设置为maliao01. Camera-A的culling mask去掉这两个层,Camera_B的culling mask只要maliao层
data:image/s3,"s3://crabby-images/7c468/7c4685054070c70307a05e3be73a004a6e1b7c77" alt=""
using UnityEngine;
using System.Collections;
using System;
using Vuforia;
public class NewBehaviourScript : MonoBehaviour {
//这个就是我们先前建立的panel
public GameObject panel;
void Update()
{
//获取相机图像
Matrix4x4 P = GL.GetGPUProjectionMatrix(Camera.main.projectionMatrix, false);
//相机位置
Matrix4x4 V = Camera.main.worldToCameraMatrix;
//识别图位置
Matrix4x4 M = panel.GetComponent<Renderer>().localToWorldMatrix;
Matrix4x4 MVP = P * V * M;
panel.GetComponent<Renderer>().material.SetMatrix("_MATRIX_MVP", MVP);//截图传入shader中处理
}
}
借鉴其他大神的shader,我这里就直接拿来用了,把这个shader赋给panel
Shader "Custom/Test" {
Properties {
_MainTex("Texture", 2D) = "white" { }
}
SubShader{
Pass{
Cull Back
CGPROGRAM
#pragma vertex vert
#pragma fragment frag
#include "UnityCG.cginc"
sampler2D _MainTex;
float4x4 _MATRIX_MVP;
struct v2f{
float4 pos : SV_POSITION;
float2 uv : TEXCOORD0;
};
v2f vert(appdata_base v){
v2f o;
float2 screenSpacePos;
float4 clipPos;
//Convert position from world space to clip space.
//Only the UV coordinates should be frozen, so use a different matrix
clipPos = mul(_MATRIX_MVP, v.vertex);
//Convert position from clip space to screen space.
//Screen space has range x=-1 to x=1
screenSpacePos.x = clipPos.x / clipPos.w;
screenSpacePos.y = clipPos.y / clipPos.w;
//the screen space range (-1 to 1) has to be converted to
//the UV range 0 to 1
o.uv.x = (0.5f*screenSpacePos.x) + 0.5f;
o.uv.y = (0.5f*screenSpacePos.y) + 0.5f;
//The position of the vertex should not be frozen, so use
//the standard UNITY_MATRIX_MVP matrix
o.pos = mul(UNITY_MATRIX_MVP, v.vertex);
return o;
}
half4 frag(v2f i) : COLOR{
half4 texcol = tex2D(_MainTex, i.uv);
return texcol;
}
ENDCG
}
}
}
到此程序完成, 他主要的原理就是利用panel位置去获取我们相机中识别图的位置,然后把图像截取出来然后赋值给模型,很简单。下面是测试图,我比较懒,直接用彩色图当识别图。
data:image/s3,"s3://crabby-images/6b716/6b716d9992bca578a07d3fdcb206e06c107f4fc0" alt=""
data:image/s3,"s3://crabby-images/8d9a2/8d9a2dcc38c32b638fd7c785151d9bc4c112681a" alt=""
data:image/s3,"s3://crabby-images/f8c0e/f8c0ed84987dcbb8cf9eaa8ad6651fca2b173ef7" alt=""
data:image/s3,"s3://crabby-images/72adb/72adb48426b7940f0c8f2bbeefab6407ceffa49a" alt=""
网友评论