简述

在传送门中,核心的玩法是在地上或者墙上打开2个可以联通的洞来实现传送的效果。以此扩展加入解谜要素构成游戏的核心。

这里尝试使用unity来实现传送门的核心功能,具体功能分析如下:

1、传送门的模型

2、传送门的贴图

3、传送门的传送功能

这里我们需要以下软件:3dmax 2014,unity3d 5.4.0,visual studio 2015

一、传送门的模型和uv

       打开3dmax,确认系统单位和显示单位都为米,如果不为米,改成米

        建立一个圆柱体,高度段数1,端面分段1,边数32,调整到适当大小,转化为可编辑多边形,删除除了顶部面之外的所有面,位置归0。再次转化为可编辑多边形。

        使用uvw展开命令,进行uv展开

        更改模型的名称和材质的名称,导出fbx文件

二、传送门的动态贴图

1、静态效果实现

        打开unity,导入模型,导入一个适当的场景包作为测试场景,创建一个可以用键盘控制的Player,用于场景游历和功能测试

        创建一个新的摄像机,放在其他位置,作为传送的目标点。创建一个RenderTexture,拖拽到摄像机的Target Texture上。将摄像机的Clear flag改为solid color。适当更改相机的Viewport Rect。

        将导入的传送门模型拖拽到场景中,放置在一面墙上,设置模型材质的贴图为RenderTexture。

        可以看到效果如下

2、动态效果实现

        传送门的效果类似与一个洞,在不同的位置看过去,显示的大小和物件都是有差别的。就类似你通过一个窗户看外面的世界类似。所以,我们要根据玩家的摄像机相对与传送门的相对位置关系,来设置目标点摄像机的相关数据,比如,视角,位置,选择和裁剪等。

  • 目标摄像机和传送点的距离=玩家和传送门的距离
  • 目标摄像机的裁剪距离=目标摄像机和传送点的距离
  • 目标摄像机始终朝向传送点
  • 目标摄像机的视角=2*Atan(传送门高度/2/目标摄像机和传送点的距离)

        注意Atan在unity中为弧度,需要再乘上Mathf.Rad2Deg转成角度

       部分代码如下(这里利用父子关系实现位置变化,目标摄像机为传送点的子物体,所以目标摄像机的localposition也就是相对于传送点的相对距离)

internal protected void Update()
{
var cpos = Camera.main.transform.position;
var mt = Render.worldToLocalMatrix;
mt = Matrix4x4.TRS(Vector3.zero, Quaternion.AngleAxis(180, Vector3.up), Vector3.one) * mt;
Camera.transform.localPosition = mt.MultiplyPoint(cpos);
Camera.transform.LookAt(Point);
Camera.nearClipPlane = -Camera.transform.localPosition.z;
const float renderHeight = 3f;
Camera.fieldOfView = 2 * Mathf.Atan(renderHeight / 2 / Camera.nearClipPlane) * Mathf.Rad2Deg;
}

三、传送功能实现

在传送门上增加一个collider,设置为Trigger,当玩家与之发生碰撞的时候设置玩家的位置数据

  • 玩家的位置=传送点的位置,
  • 玩家相对与传送点的朝向=传送前,玩家相对于传送门的朝向

        部分代码如下

internal protected void OnTriggerEnter(Collider other)
{
other.transform.root.rotation = other.transform.root.rotation * Point.rotation * Render.rotation;
other.transform.root.position = Point.position;
}

总结

        本项目整体难度不大,大约花费时间2天

        目前项目已经开源,地址为http://git.oschina.net/CodeGize/PortalGame,可以前往下载

        演示地址:http://v.youku.com/v_show/id_XMTY5MzE3MzU0MA==.html

unity传送门类似效果实现的更多相关文章

  1. Unity Shader - 消融效果原理与变体

    基本原理与实现 主要使用噪声和透明度测试,从噪声图中读取某个通道的值,然后使用该值进行透明度测试. 主要代码如下: fixed cutout = tex2D(_NoiseTex, i.uvNoiseT ...

  2. unity,荧光效果(bloom)实现过程

    两个月前,刚接触unity的时候费了半天劲儿做了个荧光效果(见:http://www.cnblogs.com/wantnon/p/4430749.html),今天终于抽空整理了一下,把过程写下来. 荧 ...

  3. 关于Unity中粒子效果的使用

    粒子效果1: 游戏中会有很炫酷的特效,比如爆炸,水花,火焰等;2: unity提供粒子编辑器,方便特效人员来开发很炫酷的特效;3.粒子效果一般有专门的粒子特效师来做,我们只需要拿来用就好了,很多参数没 ...

  4. unity 图片 粉碎效果 破碎效果

    效果: 点击按钮后: 这些碎片具有物理碰撞效果,下面会有隐形的支柱垫着碎片,n秒后支柱消失,碎片落下 当然你也可以控制生成的碎片,让他们从下而上一块一块地落下 插件源码: https://github ...

  5. Unity光晕剑效果的Shader简单实现

    最近遇到了一个需求,想要一种在刀剑上带有光晕的酷炫效果,甚至是还想要有闪烁呼吸效果,于是就写了一个简单的叫LightSwrod的Shader去实现,先上图看看效果吧. 简单展示 这是剑本身的样子 这是 ...

  6. Unity音乐喷泉效果

    本文参考了该文,其素材也取之于该处 效果 实现效果(根据音乐的高低会产生不同的波纹): 可以观看视频来获得更好的体验. 波纹的实现 先模拟出如下效果: 通过鼠标的点击,产生一个扩散的圆圈. 如上图所示 ...

  7. Unity 实现橡皮擦效果

    我所实现的橡皮擦效果是设置图片某点的像素的透明度为0,来简单实现擦除效果的: 下面是效果 首先需要注意两点:1:设置 Main Camera 的 projection 属性为Orthographic ...

  8. Unity 屏幕震动效果实现

    要实现震屏效果其实并不难,所谓的震屏在PC端可以简单地理解为相机(MainCamera)的抖动. 代码实现如下: using UnityEngine; using System.Collections ...

  9. unity 实现流光效果

    1.通过一些简单效果可以让我们更好的去理解shader,具体都在代码注释中: Shader "Unlit/MoveLightImage" { Properties { //主纹理 ...

随机推荐

  1. java程序测试之字节流

    package filestream; import java.io.FileInputStream; import java.io.FileNotFoundException; import jav ...

  2. 改变radio默认样式

    改变radio默认样式,代码如下: <!doctype html> <html> <head> <meta charset="UTF-8" ...

  3. ZooKeeper的不同类型的Znodes

    在ZooKeeper中有3个不同类型的znodes:persistent, ephemeral, sequential Persistent Znodes(默认)在ZooKeeper中,这是默认的zn ...

  4. 关于Console控制台输出的玩法

    你在浏览网页的时候,是否注意过这些网页的控制台输出了什么? Console这种东西,其实一般只有前端工作者才会注意到.console在我们实际开发中可是个宝贝,他是各种error和warning的展示 ...

  5. groovy学习(一)列表

    numbers = [11, 12, 13, 14]println(numbers[0])println(numbers[3])println(numbers[-1])//最左边的元素println( ...

  6. 支持缩放的fresco图片控件 —— fresco sample: ZoomableDraweeView

    最近在实现一个类似淘宝中的评论列表的功能,其中要在列表中显示评论图,点击图片后显示大图进行查看,各家app几乎都会有这样的功能. 可以看到,一个体验较好的查看大图的基本功能有, 第一,左右滑动时切换图 ...

  7. 【Zookeeper】源码分析之请求处理链(四)

    一.前言 前面分析了SyncReqeustProcessor,接着分析请求处理链中最后的一个处理器FinalRequestProcessor. 二.FinalRequestProcessor源码分析 ...

  8. Spring+SpringMVC+MyBatis+easyUI整合基础篇(三)搭建步骤

    框架介绍: 主角即Spring.SpringMVC.MyBatis.easyUI,大家应该也都有所了解,概念性的东西就不写了,有万能的百度.   工作环境:       jdk 1.7       m ...

  9. canvas绘图不清晰的解决方案

    现象描述 同样大小的图片(60x60px)用canvas和DOM绘制,结果发现canvas的画面质量要差很多.结果如下图所示. 上图中,左侧红框中的金币采用DOM绘制,右侧和下方的金币和文字等使用ca ...

  10. Hibernate双向关联的增删改操作的属性

    双向关联关系下的增删改操作的属性                    1.cascade属性:  eg:<set name = "emps" cascade="s ...