【Unity技能】做一个简单的NPC

1. 写在前面

前几天我看到cgcookie一个教程。学习了下怎么依据已有人物模型制作一个仿版的NPC人物。感觉挺好玩的,整理一下放到博客里!

先看一下教程里面的终于效果。

是不是非常像个幽灵~

以下是我在自己的project中实验的结果。

中间是游戏角色。两遍两个就是NPC啦。

这样的技术得到的效果和贴图关系非常大。所以假设效果不好再画一张贴图吧

2. 实现

实现非常easy,一共包括三个部分:改变Mesh材质,给Mesh加入Particle,最后加入闪烁的脚本

2.1 改变Mesh材质

  • 首先新建一个空白对象。能够命名为holo_character,给它加入Mesh Filter和Mesh Render组件。

  • 将原模型的Mesh赋值给上述Mesh Filter组件。

    然后新建一个材质,并赋值给Mesh Render组件来替换原来的模型材质。

    新的材质使用Particles/Additive的Shader,贴图属性中使用这个NPC的贴图,也也能够直接使用原模型的材质贴图。材质颜色能够依据喜好自行调节。面板设置例如以下:

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY2FuZHljYXQxOTky/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" style="font-size:14px;" />

  • 假设你的模型包括多个Mesh,比如头和身体是分开的,那么对每一个部分都做如上操作即可了。

如今你的NPC应该看起来幽灵化了。

2.2 给Mesh加入Particle

给holo_character依次加入Mesh Particle Emitter、Particle Animator和Particle Render组件。

将上一步新建的材质赋值给Particle Render中的材质对象。到了这里基本外观就出来了。

然后,能够依据须要调整对应的參数来得到想要的效果。比如,能够调整Mesh Particle Emitter中的Min Size,Max Size来调整粒子的大小,调整MinEnergy和Max Energy来调整每一个粒子的持续时间。调整Min Emission和Max Emission来调整同一时间粒子的个数等。

2.3 加入闪烁脚本

最后,为了让这个NPC看起来更像一个幽灵。我们加入一个闪烁的脚本。这个脚本的主要原理就是控制材质的透明度。非常easy。新建一个脚本FlickeringScript.cs。代码例如以下:

using UnityEngine;
using System.Collections;

public class FlickeringScript : MonoBehaviour {

	private Color color;

	// Use this for initialization
	void Start () {
		color = renderer.material.GetColor("_TintColor");
		StartCoroutine(WaitForColor());
	}

	IEnumerator WaitForColor() {
		while (true) {
			yield return new WaitForSeconds(Random.Range(0.0f, 0.1f));
			color.a = Random.Range(0.0f, 0.5f);
			renderer.material.SetColor("_TintColor", color);
		}
	}
}

将上述代码加入到holo_character。

3. 最后的话

这是一种非常tricky的做法,能够通过调整粒子效果来得到不同类型的NPC,比如火焰性等等。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY2FuZHljYXQxOTky/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" />

另一点要说明,假设你的模型绑定了骨骼动画的。那么模型上应该会自己主动绑定Skin Mesh Render组件,并且模型又是标准的T型,例如以下图这样。那么能够变通一下,NPC也使用Skin Mesh Render来播放动画,不至于让NPC一直都是伸展着胳膊的。。。

可是这样加入粒子时使用Mesh Particle Emitter就没实用了。

假设这样,我们能够自行调整粒子效果,得到其它的效果也是不错的~

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY2FuZHljYXQxOTky/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" />

最后,假设您认为本文对您有所帮助,请帮小女子投一票吧。谢谢~

http://vote.blog.csdn.net/Article/Details?articleid=30241041

版权声明:本文博客原创文章,博客,未经同意,不得转载。

时间: 2024-10-28 21:58:38

【Unity技能】做一个简单的NPC的相关文章

使用Multiplayer Networking做一个简单的多人游戏例子-2/3(Unity3D开发之二十六)

猴子原创,欢迎转载.转载请注明: 转载自Cocos2Der-CSDN,谢谢! 原文地址: http://blog.csdn.net/cocos2der/article/details/51007512 使用Multiplayer Networking做一个简单的多人游戏例子-1/3 使用Multiplayer Networking做一个简单的多人游戏例子-2/3 使用Multiplayer Networking做一个简单的多人游戏例子-3/3 7. 在网络中控制Player移动 上一篇中,玩家操

使用React并做一个简单的to-do-list

1. 前言 说到React,我从一年之前就开始试着了解并且看了相关的入门教程,而且还买过一本<React:引领未来的用户界面开发框架 >拜读.React的轻量组件化的思想及其visual-dom的这种技术创新,也算是早就有了初步了解.一来没有学的太深入,二来后来在工作中和业余项目中都没有用到,因此慢慢的就更加生疏了. 近期,因为我想把自己的开源项目wangEditor能放在React.angular和vuejs中使用.先从react开始,顺手自己也重试一下React的基础知识,顺便再做一个小d

[3] 用D3.js做一个简单的图表吧!

本人的个人博客为: www.ourd3js.com csdn博客为: blog.csdn.net/lzhlzz 转载请注明出处,谢谢. 前面说了几节,都是对文字进行处理,这一节中将用 D3.js 做一个简单的柱形图. 做柱形图有很多种方法,比如用 HTML 的 div 标签,或用 svg . 推荐用 SVG 来做各种图形.SVG 意为可缩放矢量图形(Scalable Vector Graphics),SVG 使用 XML 格式定义图像,不清楚什么是SVG的朋友请先在 w3cschools 学习下

用EF DataBase First做一个简单的MVC3报名页面

使用EF DataBase First做一个简单的MVC3报名网站 ORM(Object Relational Mapping)是面向对象语言中的一种数据访问技术,在ASP.NET中,可以通过ADO.NET Entity Framework技术来简化数据访问.在EF里,有Code First,Model First和DataBase First三种方法来实现. 百度百科关于ORM的介绍: http://baike.baidu.com/view/197951.htm?fr=aladdin 1.就像

【Python】 做一个简单的 http 服务器

# coding=utf-8 ''' Created on 2014年6月15日 @author: Yang ''' import socket import datetime # 初始化socket s = socket.socket() # 获取主机名, 也可以使用localhost # host = socket.gethostname() host = "localhost" # 默认的http协议端口号 port = 80 # 绑定服务器socket的ip和端口号 s.bin

Jmeter初步使用二--使用jmeter做一个简单的性能测试

经过上一次的初步使用,我们懂得了Jmeter的安装与初步使用的方法.现在,我们使用Jmeter做一个简单的性能测试.该次测试,提交的参数不做参数化处理,Jmeter各元件使用将在介绍在下一博文开始介绍并使用. 首先,打开Jmeter工具,并建立一个测试计划(测试脚本).启动jmeter后,jmeter会自动生成一个空的测试计划,我们可以基于该测试计划建立自己的测试计划. 步骤: 步骤一:添加线程组 一个性能测试请求负载是基于一个线程组完成的.一个测试计划必须有一个线程组.测试计划添加线程组非常简

【 D3.js 入门系列 — 3 】 做一个简单的图表!

图1. 柱形图 1. 柱形图 前几章的例子,都是对文字进行处理.本章中将用 D3 做一个简单的柱形图.制作柱形图有很多种方法,比如用 HTML 的 <div> 标签,或在 SVG 上绘制 . SVG ,即可缩放矢量图形(Scalable Vector Graphics),使用 XML 格式定义图形,可在 W3School 学习 SVG 的相关语法,不需要记住所有标签,用的时候再查即可. 先看下面的代码: <script src="http://d3js.org/d3.v3.mi

【Bugly干货分享】一起用 HTML5 Canvas 做一个简单又骚气的粒子引擎

Bugly 技术干货系列内容主要涉及移动开发方向,是由Bugly邀请腾讯内部各位技术大咖,通过日常工作经验的总结以及感悟撰写而成,内容均属原创,转载请标明出处. 前言 好吧,说是“粒子引擎”还是大言不惭而标题党了,离真正的粒子引擎还有点远.废话少说,先看[demo],扫描后点击屏幕有惊喜哦… 本文将教会你做一个简单的canvas粒子制造器(下称引擎). 世界观 这个简单的引擎里需要有三种元素:世界(World).发射器(Launcher).粒子(Grain).总得来说就是:发射器存在于世界之中,

初学者如何做一个简单的计算器,代码分享

先新建一个类 startCalculator 声明如下 #import <Foundation/Foundation.h> @interface StartCalculator : NSObject //声明两个要计算的变量 @property float opValue1; @property float opValue2; //声明一个运算符 @property char op; //普通方法 //- (float) gzyWorkAdd; // //- (float) gzyWorkSu