查看: 2605|回复: 9
打印 上一主题 下一主题

摄像机的效果代码系列——自定义形状切换

[复制链接]

1023

主题

3

听众

359

积分

设计实习生

Rank: 2

纳金币
335582
精华
0

最佳新人

跳转到指定楼层
楼主
发表于 2011-8-12 10:50:05 |只看该作者 |倒序浏览
你可以随意定义画面切换时是什么形状的,多奇怪的都行!

上下键控制图片切换,“1”、“2”、“3”控制你要的图形,默认的是三个形状,你可以自己添加
var camera1 : Camera;

var camera2 : Camera;

var wipeTime = 2.0;

var rotateAmount = 360.0;

var shapeMesh : Mesh[];

private var inProgress = false;

private var swap = false;

private var useShape = 0;

function Update () {

if (Input.GetKeyDown("up")) {

DoWipe(ZoomType.Grow);

}

else if (Input.GetKeyDown("down")) {

DoWipe(ZoomType.Shrink);

}

if (Input.GetKeyDown("1")) {useShape = 0;}

if (Input.GetKeyDown("2")) {useShape = 1;}

if (Input.GetKeyDown("3")) {useShape = 2;}

}

function DoWipe (zoom : ZoomType) {

if (inProgress) return;

inProgress = true;
swap = !swap;

yield ScreenWipe.use.ShapeWipe (swap? camera1 : camera2, swap? camera2 : camera1, wipeTime, zoom, shapeMesh[useShape], rotateAmount);
inProgress = false;
}

private var tex : Texture;

private var renderTex : RenderTexture;

private var tex2D : Texture2D;

private var alpha : float;

private var reEnableListener : boolean;

private var shapeMaterial : Material;

private var shape : Transform;

static var use : ScreenWipe;

enum ZoomType {Grow, Shrink}

enum TransitionType {Left, Right, Up, Down}

function Awake () {

if (use) {

Debug.LogWarning("Only one instance of ScreenWipe is allowed");

return;

}

use = this;

this.enabled = false;

}

function OnGUI () {

GUI.depth = -9999999;

GUI.color.a = alpha;

GUI.DrawTexture(Rect(0, 0, Screen.width, Screen.height), tex);

}

function AlphaTimer (time : float) {

var rate = 1.0/time;

for (alpha = 1.0; alpha > 0.0; alpha -= Time.deltaTime * rate) {

yield;

}

}

function CameraSetup (cam1 : Camera, cam2 : Camera, cam1Active : boolean, enableThis : boolean) {

if (enableThis) {

this.enabled = true;

}

cam1.gameObject.active = cam1Active;

cam2.gameObject.active = true;

var listener : AudioListener = cam2.GetComponent(AudioListener);

if (listener) {

reEnableListener = listener.enabled? true : false;

listener.enabled = false;

}

}

function CameraCleanup (cam1 : Camera, cam2 : Camera) {

var listener : AudioListener = cam2.GetComponent(AudioListener);

if (listener && reEnableListener) {

listener.enabled = true;

}

cam1.gameObject.active = false;

this.enabled = false;

}

function CrossFadePro (cam1 : Camera, cam2 : Camera, time : float) {

if (!renderTex) {

renderTex = new RenderTexture(Screen.width, Screen.height, 24);

}

cam1.targetTexture = renderTex;

tex = renderTex;

CameraSetup (cam1, cam2, true, true);
yield AlphaTimer(time);
cam1.targetTexture = null;

renderTex.Release();

CameraCleanup (cam1, cam2);

}

function CrossFade (cam1 : Camera, cam2 : Camera, time : float) {

if (!tex2D) {

tex2D = new Texture2D(Screen.width, Screen.height, TextureFormat.RGB24, false);

}

tex2D.ReadPixels(Rect(0, 0, Screen.width, Screen.height), 0, 0, false);

tex2D.Apply();

tex = tex2D;

yield;

CameraSetup (cam1, cam2, false, true);

yield AlphaTimer(time);

CameraCleanup (cam1, cam2);

}

function RectWipe (cam1 : Camera, cam2 : Camera, time : float, zoom : ZoomType) {

CameraSetup (cam1, cam2, true, false);

var useCam = (zoom == ZoomType.Shrink)? cam1 : cam2;

var otherCam = (zoom == ZoomType.Shrink)? cam2 : cam1;

var originalRect = useCam.rect;

var originalDepth = useCam.depth;

useCam.depth = otherCam.depth+1;

var rate = 1.0/(time*2);

if (zoom == ZoomType.Shrink) {

for (i = 0.0; i < .5; i += Time.deltaTime * rate) {

var t = Mathf.Lerp(0.0, .5, Mathf.Sin(i * Mathf.PI)); // Slow down near the end

cam1.rect = Rect(t, t, 1.0-t*2, 1.0-t*2);

yield;

}

}

else {

for (i = 0.0; i < .5; i += Time.deltaTime * rate) {

t = Mathf.Lerp(.5, 0.0, Mathf.Sin((.5-i) * Mathf.PI)); // Start out slower

cam2.rect = Rect(.5-t, .5-t, t*2, t*2);

yield;

}

}

useCam.rect = originalRect;

useCam.depth = originalDepth;

CameraCleanup (cam1, cam2);

}

function ShapeWipe (cam1 : Camera, cam2 : Camera, time : float, zoom : ZoomType, mesh : Mesh, rotateAmount : float) {

if (!shapeMaterial) {

shapeMaterial = new Material (

"Shader "DepthMask" {" +

" SubShader {" +

" Tags { "Queue" = "Background" }" +

" Lighting Off ZTest LEqual ZWrite On Cull Off ColorMask 0" +

" Pass {}" +

" }" +

"}"

);

}

if (!shape) {

shape = new GameObject("Shape", MeshFilter, MeshRenderer).transform;

shape.renderer.material = shapeMaterial;

}

CameraSetup (cam1, cam2, true, false);

var useCam = (zoom == ZoomType.Shrink)? cam1 : cam2;

var otherCam = (zoom == ZoomType.Shrink)? cam2 : cam1;

var originalDepth = otherCam.depth;

var originalClearFlags = otherCam.clearFlags;

otherCam.depth = useCam.depth+1;

otherCam.clearFlags = CameraClearFlags.Depth;

shape.gameObject.active = true;

(shape.GetComponent(MeshFilter) as MeshFilter).mesh = mesh;

shape.position = otherCam.transform.position + otherCam.transform.forward * (otherCam.nearClipPlane+.01);

shape.parent = otherCam.transform;

shape.localRotation = Quaternion.identity;

var rate = 1.0/time;

if (zoom == ZoomType.Shrink) {

for (i = 1.0; i > 0.0; i -= Time.deltaTime * rate) {

var t = Mathf.Lerp(1.0, 0.0, Mathf.Sin((1.0-i) * Mathf.PI * 0.5)); // Slow down near the end

shape.localScale = Vector3(t, t, t);

shape.localEulerAngles = Vector3(0.0, 0.0, i * rotateAmount);

yield;

}

}

else {

for (i = 0.0; i < 1.0; i += Time.deltaTime * rate) {

t = Mathf.Lerp(1.0, 0.0, Mathf.Sin((1.0-i) * Mathf.PI * 0.5)); // Start out slower

shape.localScale = Vector3(t, t, t);

shape.localEulerAngles = Vector3(0.0, 0.0, -i * rotateAmount);

yield;

}

}

otherCam.clearFlags = originalClearFlags;

otherCam.depth = originalDepth;

CameraCleanup (cam1, cam2);

shape.parent = null;

shape.gameObject.active = false;

}

function SquishWipe (cam1 : Camera, cam2 : Camera, time : float, transitionType : TransitionType) {

var originalCam1Rect = cam1.rect;

var originalCam2Rect = cam2.rect;

var cam1Matrix = cam1.projectionMatrix;

var cam2Matrix = cam2.projectionMatrix;

CameraSetup (cam1, cam2, true, false);
var rate = 1.0/time;

for (i = 0.00; i < 1.0; i += Time.deltaTime * rate) {

switch (transitionType) {

case TransitionType.Right:

cam1.rect = Rect(i, 0, 1.0, 1.0);

cam2.rect = Rect(0, 0, i, 1.0);

break;

case TransitionType.Left:

cam1.rect = Rect(0, 0, 1.0-i, 1.0);

cam2.rect = Rect(1.0-i, 0, 1.0, 1.0);

break;

case TransitionType.Up:

cam1.rect = Rect(0, i, 1.0, 1.0);

cam2.rect = Rect(0, 0, 1.0, i);

break;

case TransitionType.Down:

cam1.rect = Rect(0, 0, 1.0, 1.0-i);

cam2.rect = Rect(0, 1.0-i, 1.0, 1.0);

break;

}

cam1.projectionMatrix = cam1Matrix;

cam2.projectionMatrix = cam2Matrix;

yield;

}
cam1.rect = originalCam1Rect;

cam2.rect = originalCam2Rect;

CameraCleanup (cam1, cam2);

}

var planeResolution = 90; // Higher numbers make the DreamWipe effect smoother, but take more CPU time

private var baseVertices : Vector3[];

private var newVertices : Vector3[];

private var planeMaterial : Material;

private var plane : GameObject;

private var renderTex2 : RenderTexture;

function InitializeDreamWipe () {

if (planeMaterial && plane) return;
planeMaterial = new Material (

"Shader "Unlit2Pass" {" +

"roperties {" +

" _Color ("Main Color", Color) = (1,1,1,1)" +

" _Tex1 ("Base", Rect) = "white" {}" +

" _Tex2 ("Base", Rect) = "white" {}" +

"}" +

"Category {" +

" ZWrite Off Alphatest Greater 0 ColorMask RGB Lighting Off" +

" Tags {"Queue"="Transparent" "IgnoreProjector"="True" "RenderType"="Transparent"}" +

" Blend SrcAlpha OneMinusSrcAlpha" +

" SubShader {" +

" Pass {SetTexture [_Tex2]}" +

" Pass {SetTexture [_Tex1] {constantColor [_Color] Combine texture * constant}}" +

" }" +

"}}"

);
// Set up plane object

plane = new GameObject("lane", MeshFilter, MeshRenderer);

plane.renderer.material = planeMaterial;

plane.renderer.castShadows = false;

plane.renderer.receiveShadows = false;

plane.renderer.enabled = false;

// Create the mesh used for the distortion effect

var planeMesh = new Mesh();

(plane.GetComponent(MeshFilter) as MeshFilter).mesh = planeMesh;
planeResolution = Mathf.Clamp(planeResolution, 1, 16380);

baseVertices = new Vector3[4*planeResolution + 4];

newVertices = new Vector3[baseVertices.Length];

var newUV = new Vector2[baseVertices.Length];

var newTriangles = new int[18*planeResolution];
var idx = 0;

for (i = 0; i <= planeResolution; i++) {

var add : float = 1.0/planeResolution*i;

newUV[idx] = Vector2(0.0, 1.0-add);

baseVertices[idx++] = Vector3(-1.0, .5-add, 0.0);

newUV[idx] = Vector2(0.0, 1.0-add);

baseVertices[idx++] = Vector3(-.5, .5-add, 0.0);

newUV[idx] = Vector2(1.0, 1.0-add);

baseVertices[idx++] = Vector3(.5, .5-add, 0.0);

newUV[idx] = Vector2(1.0, 1.0-add);

baseVertices[idx++] = Vector3(1.0, .5-add, 0.0);

}
idx = 0;

for (y = 0; y < planeResolution; y++) {

for (x = 0; x < 3; x++) {

newTriangles[idx++] = (y*4 )+x;

newTriangles[idx++] = (y*4 )+x+1;

newTriangles[idx++] = ((y+1)*4)+x;

newTriangles[idx++] = ((y+1)*4)+x;

newTriangles[idx++] = (y *4)+x+1;

newTriangles[idx++] = ((y+1)*4)+x+1;

}

}
planeMesh.vertices = baseVertices;

planeMesh.uv = newUV;

planeMesh.triangles = newTriangles;
// Set up rendertextures

renderTex = new RenderTexture(Screen.width, Screen.height, 24);

renderTex2 = new RenderTexture(Screen.width, Screen.height, 24);

renderTex.filterMode = renderTex2.filterMode = FilterMode.Point;

planeMaterial.SetTexture("_Tex1", renderTex);

planeMaterial.SetTexture("_Tex2", renderTex2);

}

function DreamWipe (cam1 : Camera, cam2 : Camera, time : float) {

yield DreamWipe (cam1, cam2, time, .07, 25.0);

}

function DreamWipe (cam1 : Camera, cam2 : Camera, time : float, waveScale : float, waveFrequency : float) {

if (!plane || !planeMaterial) {

InitializeDreamWipe();

}

waveScale = Mathf.Clamp(waveScale, -.5, .5);

waveFrequency = .25/(planeResolution/waveFrequency);
CameraSetup (cam1, cam2, true, false);

// Make a camera that will show a plane with the combined rendertextures from cam1 and cam2,

// and make it have the highest depth so it's always on top

var cam2Clone : Camera = Instantiate(cam2, cam2.transform.position, cam2.transform.rotation);

cam2Clone.depth = cam1.depth+1;

if (cam2Clone.depth <= cam2.depth) {

cam2Clone.depth = cam2.depth+1;

}

// Get screen coodinates of 0,0 in local spatial coordinates, so we know how big to scale the plane (make sure clip planes are reasonable)

cam2Clone.nearClipPlane = .5;

cam2Clone.farClipPlane = 1.0;

var p = cam2Clone.transform.InverseTransformPoint(cam2.ScreenToWorldPoint(Vector3(0.0, 0.0, cam2Clone.nearClipPlane)));

plane.transform.localScale = Vector3(-p.x*2.0, -p.y*2.0, 1.0);

plane.transform.parent = cam2Clone.transform;

plane.transform.localPosition = plane.transform.localEulerAngles = Vector3.zero;

// Must be a tiny bit beyond the nearClipPlane, or it might not show up

plane.transform.Translate(Vector3.forward * (cam2Clone.nearClipPlane+.00005));

// Move the camera back so cam2 won't see the renderPlane, and parent it to cam2 so that if cam2 is moving, it won't see the plane

cam2Clone.transform.Translate(Vector3.forward * -1.0);

cam2Clone.transform.parent = cam2.transform;
// Initialize some stuff

plane.renderer.enabled = true;

var scale = 0.0;

var planeMesh = (plane.GetComponent(MeshFilter) as MeshFilter).mesh;

cam1.targetTexture = renderTex;

cam2.targetTexture = renderTex2;

// Do the cross-fade

var rate = 1.0/time;

for (i = 0.0; i < 1.0; i += Time.deltaTime * rate) {

planeMaterial.color.a = Mathf.SmoothStep(0.0, 1.0, Mathf.InverseLerp(.85, .25, i));

// Make plane undulate

for (var j = 0; j < newVertices.Length; j++) {

newVertices[j] = baseVertices[j];

newVertices[j].x += Mathf.Sin(j*waveFrequency + i*time) * scale;

}

planeMesh.vertices = newVertices;

scale = Mathf.Sin(Mathf.PI * Mathf.SmoothStep(0.0, 1.0, i)) * waveScale;

yield;

}
// Clean up

CameraCleanup (cam1, cam2);

plane.renderer.enabled = false;

plane.transform.parent = null;

Destroy(cam2Clone.gameObject);

cam1.targetTexture = cam2.targetTexture = null;

renderTex.Release();

renderTex2.Release();

}
分享到: QQ好友和群QQ好友和群 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
转播转播0 分享淘帖0 收藏收藏0 支持支持0 反对反对0
回复

使用道具 举报

1274

主题

1

听众

4万

积分

禁止发言

纳金币
43676
精华
4
沙发
发表于 2011-8-12 21:29:54 |只看该作者
好长呀,头晕
回复

使用道具 举报

5969

主题

1

听众

39万

积分

首席设计师

Rank: 8Rank: 8

纳金币
-1
精华
0

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

板凳
发表于 2011-12-30 18:21:10 |只看该作者
顶!学习了!阅!
回复

使用道具 举报

5969

主题

1

听众

39万

积分

首席设计师

Rank: 8Rank: 8

纳金币
-1
精华
0

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

地板
发表于 2012-2-21 23:23:37 |只看该作者
心中有爱,爱咋咋地
回复

使用道具 举报

5969

主题

1

听众

39万

积分

首席设计师

Rank: 8Rank: 8

纳金币
-1
精华
0

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

5#
发表于 2012-4-11 23:34:21 |只看该作者
凡系斑竹滴话要听;凡系朋友滴帖要顶
回复

使用道具 举报

markq    

511

主题

1

听众

1万

积分

资深设计师

Rank: 7Rank: 7Rank: 7

纳金币
15839
精华
0

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

6#
发表于 2012-4-12 22:47:17 |只看该作者
不错 非常经典 实用
回复

使用道具 举报

   

671

主题

1

听众

3247

积分

中级设计师

Rank: 5Rank: 5

纳金币
324742
精华
0

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

7#
发表于 2012-4-12 23:27:08 |只看该作者
我看看就走,你们聊!
回复

使用道具 举报

5969

主题

1

听众

39万

积分

首席设计师

Rank: 8Rank: 8

纳金币
-1
精华
0

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

8#
发表于 2012-5-9 23:20:26 |只看该作者
人过留名!
回复

使用道具 举报

1023

主题

3

听众

359

积分

设计实习生

Rank: 2

纳金币
335582
精华
0

最佳新人

9#
发表于 2013-1-29 23:29:51 |只看该作者
百度的叫度娘,网易的叫易娘,新浪内部还在为是叫新娘还是浪娘而争论不休!……不管你们是企鹅的额娘,豆瓣的伴娘,还是华为的伪娘,都要记得,淘宝才是你们的亲娘啊!亲!!
回复

使用道具 举报

5969

主题

1

听众

39万

积分

首席设计师

Rank: 8Rank: 8

纳金币
-1
精华
0

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

10#
发表于 2013-1-30 23:25:02 |只看该作者
无聊时可以刷屏幕 灌水 也可以试试 帖子的标题究竟可以写多长
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

手机版|纳金网 ( 闽ICP备2021016425号-2/3

GMT+8, 2025-1-15 20:43 , Processed in 0.068927 second(s), 28 queries .

Powered by Discuz!-创意设计 X2.5

© 2008-2019 Narkii Inc.

回顶部