通过前面的制作,我们已经能够让子弹出现,并且射击,但是如何让子弹跟随我们的视角进行射击呢?而不是跟随枪口实例化出来的位置进行移动。
引用摄像机:
void Shoot()
{
playFlash.PlayFalsh();
// 实例化子弹对象到当前的物体
GameObject go = Instantiate(bullet, transform.position, transform.rotation) as GameObject;
// 获取当前视野
Vector3 current = MainCame.ScreenToWorldPoint(new Vector3(Screen.width / 2, Screen.height / 2, 0));
RaycastHit hit;
bool isCollider = Physics.Raycast(current, MainCame.transform.forward, out hit);
if (isCollider)
{
go.transform.LookAt(hit.point);
}
else
{
current += MainCame.transform.forward * 600;
go.transform.LookAt(current);
}
}
接着导入游戏的运行场景,删除场景中自带的角色控制器
改个名字,扔进我们的Scenes中
2、制作游戏开始UI
登陆界面:
tween动画下面的finished属性: 即当前动画播放后执行什么操作
3、给我们的场景服务器添加游戏控制器脚本:GameController
4、实例化我们的角色
我们可以设置一个空的游戏对象,然后将我们的敌人和战士一同挂在它的子物体下
最好使用NetWork.Instantiate();
5、客户端链接服务器并创建角色
设置准心,
通过GIUTexture来进行,看不到可以给它添加一个子物体的摄像机。
隐藏鼠标 只需要在初始化服务器,客户端连接服务器的方法中:
给创建的角色添加一个Move 脚本:其中根据是哪个端来进行控制
之前测试角色移动就是通过下面脚本进行,所以我们根据判断出那个客户端来进行控制。
同时禁用掉射击功能或者所有的能够影响两者的共同脚本:
获取射击脚本,设置射击脚本的enable 为 false
同时提供设置player 的方法:
在我们GameController中:
最终我们要禁止掉的脚本
坑一:
RPC:
RPC 的全称是 Remote Procedure Call 是一种进程间通信方式。它允许程序调用另一个地址空间(通常是共享网络的另一台机器上)的过程或函数,而不用程序员显式编码这个远程调用的细节。即程序员无论是调用本地的还是远程的,本质上编写的调用代码基本相同。
远程过程调用(RPC)让你调用一个远程计算机的函数。就好像调用一个普通函数一样容易,但也需要理解.RPC调用通常用于执行一些事件,根据所有游戏客户端或者特定的范围内双方的事件信息。
一些重要的不同
如果发现角色不能很好的创建,那么我们就需要通过RPC调用:第一个参数方法名字,第二个所有的客户端,第三个前面方法的参数
方法因为被RPC调用所以【RPC】标注一下:
同理在服务器连接客户端的方法中,仿照上述方法,直接就可以搞定两端的连接了。
如果发现不能禁止其他客户端的游戏角色控制,可以重新获取一次脚本
我们再通过RPC方法调用方法,需要在方法上面标注【PRC】
同步动画效果:
void Update() {
if (player.Hp > 0)
{
if (charactor.isGrounded == false)
{
networkV.RPC("PlayAni", RPCMode.All, s1);
}
else
{
float h = Input.GetAxis("Horizontal");
float v = Input.GetAxis("Vertical");
if (Mathf.Abs(h) > 0.2 || Mathf.Abs(v) > 0.2)
{
networkV.RPC("PlayAni", RPCMode.All, s2);
}
else
{
networkV.RPC("PlayAni", RPCMode.All, s3);
}
}
}
else {
if (isPlayDieAni == false)
{
networkV.RPC("PlayAni", RPCMode.AllBuffered, "soldierDieFront");
isPlayDieAni = true;
}
}
}
// 传入名字播放动画
[RPC]
public void PlayAni(string aniName)
{
// 因为start方法只调用一次,刚开始进去就会调用,而后面就不会调用了.
// 如果动画不同步,那么就是我们的Start方法不调用,所以获取不到Animation组件
GetComponent<Animation>().CrossFade(aniName, 0.5f);
// 控制动画播放速度
// ani[aniName].speed = 2.0f;
}
来吧少年互相伤害:
6、杀戮时刻
给子弹脚本添加我们的伤害值
public float damage = 10;
给角色添加生命值
// 接下来在我们子弹方法中:
if(hit.collider.tag == "Player")
{
hit.collider.GetComponent<Player>().TakeDamage(this.damage);
}
//完善死亡动画
在角色控制脚本中完成伤害同步
吸收伤害:
7、音乐:
添加音乐,设置音乐为2D音乐。
子弹的音乐可以直接扔进预制物中,这样每次创建出来都会播放音乐
8、结束面板
按钮事件注册一下
控制战斗的胜利或者失败
隐藏面板显示我们的结束面板,同时显示鼠标,继续游玩或者退出
9、参考资料
http://blog.csdn.net/w00w12l/article/details/46290865
http://blog.csdn.net/w00w12l/article/details/46290857
http://www.manew.com/youxizz/2390.html
简书:Network Lobby
http://blog.csdn.net/u010019717/article/details/46993697
http://blog.csdn.net/u010019717/article/details/46994409
http://blog.csdn.net/u010019717/article/details/47032099