8.虚拟键盘实现

概述:

硬键盘就是物理键盘,平时敲的那种。软键盘是虚拟的键盘,不是在键盘上,而是在"屏幕"上。虚拟按键就是虚拟键盘的一部分,根据功能需求,提供部分按键效果的UI可操控按钮,尤其是在平板电脑、触控手机上,虚拟按键得到了更多的应用。在触控平台上的游戏,一部分通过手指在屏幕上相应的滑动产生相应的指令;还有一部分增设虚拟按键,完成对游戏的操控。

实现原理:

UI基本制作->功能实现

实现方法:

步骤1:

按照7UI的制作方法,完成UI的制作,最终效果图,如8-1-1所示。左侧为摇杆按钮,为双侧的BUTTON,一层做摇杆的底部按钮背景,一层与用户交互发生相应事件。右侧围控制攻击和跳跃的按钮。


图8-1-1

步骤2:

脚本实现按钮功能。

初始化虚拟按键UI。

public void Init()

{

 //注册攻击按钮layout文件

 GUI.RegisterLayout(_attackWindowName, @"Layout\AttackButton.layout", false, true);

 //注册按钮点击事件 1.layout名字 2.控件名字 3.回调函数 4.事件控制类型

 GUI.UIWidget.SetEventMouseButtonClick(_attackWindowName, "AttackBtn",  OnAttackBtnClick, EventControl.Add);

 //注册跳跃按钮layout文件

 GUI.RegisterLayout(_jumpWindowName, @"Layout\JumpButton.layout", false, true);

 //注册按钮点击事件 1.layout名字 2.控件名字 3.回调函数 4.事件控制类型

 GUI.UIWidget.SetEventMouseButtonClick(_jumpWindowName, "JumpBtn", OnJumpBtnClick, EventControl.Add);

 //根据屏幕尺寸设定按钮位置

 IntSize screenSize = GUI.GetScreenSize();

 IntPoint AtkBtnUIpos = new IntPoint((int)(screenSize.width - GUI.UIWidget.GetSize(_attackWindowName, "_Main").width * 2.5f),

                             (int)(screenSize.height - GUI.UIWidget.GetSize(_attackWindowName, "_Main").height * 1.2f));

 IntPoint JumpBtnUIpos = new IntPoint((int)(screenSize.width - GUI.UIWidget.GetSize(_attackWindowName, "_Main").width * 1.2f),

                             (int)(screenSize.height - GUI.UIWidget.GetSize(_attackWindowName, "_Main").height * 1.2f));

 GUI.UIWidget.SetPosition(_attackWindowName, "_Main", AtkBtnUIpos);

 GUI.UIWidget.SetPosition(_jumpWindowName, "_Main", JumpBtnUIpos);

}

//攻击点击回调函数

private void OnAttackBtnClick(FString sender)

{

 Logic.IputMgr.Instance.Attack_N(Code.J);

}

//跳跃点击回调函数

private void OnJumpBtnClick(FString sender)

{

 Logic.IputMgr.Instance.Jump();

}

虚拟摇杆类

  public class AndroidJoystick

  {

   public void Init()

   {

    GUI.RegisterLayout(_joystickWindowName, @"Layout\JoyStickBtn.layout", false, true);

    //注册按钮按下事件

    GUI.UIWidget.SetEventMouseButtonPressed(_joystickWindowName, "JoystickBtn", OnJSBtnPressed, EventControl.Add);

    //注册按钮抬起事件

    GUI.UIWidget.SetEventMouseButtonReleased(_joystickWindowName, "JoystickBtn", OnJSBtnReleased, EventControl.Add);

    //注册按钮的拖拽事件

    GUI.UIWidget.SetEventMouseDrag(_joystickWindowName, "JoystickBtn", OnJSBtnDrag, EventControl.Add);

    //注册按钮的Tick事件

    GUI.UIWidget.SetEventTick(_joystickWindowName, "JoystickBtn", Tick, EventControl.Add);

    IntSize screenSize = GUI.GetScreenSize();

    IntPoint JoystickBtnUIpos = new IntPoint((int)(GUI.UIWidget.GetSize(_joystickWindowName, "_Main").width * 0.2f),

                                     (int)(screenSize.height - GUI.UIWidget.GetSize(_joystickWindowName, "_Main").height * 1.5f));

    GUI.UIWidget.SetPosition(_joystickWindowName, "_Main", JoystickBtnUIpos);

    GUI.SetLayoutVisible(_joystickWindowName, true);

    jsBtnPos = GUI.UIWidget.GetPosition(_joystickWindowName, "JoystickBtn");

    _isCtrl = false;

   }

   private void OnJSBtnDrag(FString sender, int value, int value2, MouseButton btn)

   {

    if (lastX == -)

    {

     lastX = value;

    }

    //跟上一帧作比较,大于0为右移,小于0为左移

    int xOffset = value - lastX;

    if (xOffset > )

    {

     Debug.Dbgout("IsRightSlide");

     IntPoint JoystickBtnUIpos = new IntPoint(, jsBtnPos.top);

     //移动按钮位置

     GUI.UIWidget.SetPosition(_joystickWindowName, "JoystickBtn", JoystickBtnUIpos);

     Logic.LogicMgr.Instance.SetDirection(Logic.Direction.Forward);

     Logic.LogicMgr.Instance.CurPlayer.State = Logic.CharacterState.Running;

    }

    else if (xOffset < )

    {

     Debug.Dbgout("IsLeftSlide");

     IntPoint JoystickBtnUIpos = new IntPoint(, jsBtnPos.top);

     //移动按钮位置

     GUI.UIWidget.SetPosition(_joystickWindowName, "JoystickBtn", JoystickBtnUIpos);

     Logic.LogicMgr.Instance.SetDirection(Logic.Direction.Backward);

     Logic.LogicMgr.Instance.CurPlayer.State = Logic.CharacterState.Running;

    }

   lastX = value;

   lastY = value2;

  }

private void OnJSBtnPressed(FString sender, int value, int value2, MouseButton btn)

{

//控制控件是否被操作

_isCtrl = true;

Debug.Dbgout("isCtrl");

}

private void OnJSBtnReleased(FString sender, int value, int value2, MouseButton btn)

{

//控制控件是否被操作

_isCtrl = false;

Debug.Dbgout("Released");

}

private void Tick(FString sender, float gameTime, float frameTickTime)

{

if (!_isCtrl)

{

//在非操作状态,设置为初始状态

GUI.UIWidget.SetPosition(_joystickWindowName, "JoystickBtn", jsBtnPos);

if (Logic.LogicMgr.Instance.CurPlayer.State == Logic.CharacterState.Running)

{

Logic.LogicMgr.Instance.CurPlayer.State = Logic.CharacterState.Idle;

}

}

}

引擎官方网站:http://www.genesis-3d.com.cn/

官方论坛:http://bbs.9tech.cn/genesis-3d/

官方千人大群:59113309   135439306

YY频道-游戏开发大讲堂(完全免费,定期开课):51735288

Genesis-3D开源游戏引擎:游戏起源,皆因有我!!!

 

《Genesis-3D开源游戏引擎--横版格斗游戏制作教程08:虚拟键盘实现》--本系列完结的更多相关文章

  1. 《Genesis-3D开源游戏引擎--横版格斗游戏制作教程:简介及目录》(附上完整工程文件)

    介绍:讲述如何使用Genesis-3D来制作一个横版格斗游戏,涉及如何制作连招系统,如何使用包围盒实现碰撞检测,软键盘的制作,场景切换,技能读表,简单怪物AI等等,并为您提供这个框架的全套资源,源码以 ...

  2. 《Genesis-3D开源游戏引擎--横版格斗游戏制作教程04:技能的输入与检测》

    4.技能的输入与检测 概述: 技能系统的用户体验,制约着玩家对整个游戏的体验.游戏角色的技能华丽度,连招的顺利过渡,以及逼真的打击感,都作为一款游戏的卖点吸引着玩家的注意.开发者在开发游戏初期,会根据 ...

  3. 《Genesis-3D开源游戏引擎--横版格斗游戏制作教程01: 资源导入》

    1. 资源导入 概述: 制作一款游戏需要用到很多资源,比如:模型.纹理.声音和脚本等.通常都是用其它相关制作资源软件,完成前期资源的收集工作.比如通常用的三维美术资源,会在Max.MAYA等相应软件中 ...

  4. 《Genesis-3D开源游戏引擎--横版格斗游戏制作教程07:UI》

    概述: UI即User Interface(用户界面)的简称.UI设计是指对软件的燃机交互.操作逻辑.界面美观的整体设计.好的UI设计不仅可以让游戏变得更有品位,更吸引玩家,还能充分体现开发者对游戏整 ...

  5. 《Genesis-3D开源游戏引擎--横版格斗游戏制作教程06:技能播放的逻辑关系》

    6.技能播放的逻辑关系 技能播放概述: 当完成对技能输入与检测之后,程序就该对输入在缓存器中的按键操作与程序读取的技能表信息进行匹配,根据匹配结果播放相应的连招技能. 技能播放原理: 按键缓存器中内容 ...

  6. 《Genesis-3D开源游戏引擎--横版格斗游戏制作教程05:技能读表》

    5.技能读表 技能读表概述: 技能读表,作为实现技能系统更为快捷的一种方式,被广泛应用到游戏开发中.技能配表,作为桥梁连接着游戏策划者和开发者在技能实现上的关系.在游戏技能开发中,开发者只需要根据策划 ...

  7. 《Genesis-3D开源游戏引擎--横版格斗游戏制作教程03:碰撞检测》

    3.碰撞检测 碰撞检测的概述: 碰撞在物理学中表现为两粒子或物体间极端的相互作用.而在游戏世界中,游戏对象在游戏世界自身并不受物理左右,为了模拟真实世界的效果,需要开发者为其添加属性,以模拟真实事件的 ...

  8. 《Genesis-3D开源游戏引擎--横版格斗游戏制作教程02:关键帧动画导入与切割》

    2. 关键帧动画导入与切割 动画的分割与导入概述: 在游戏当中,游戏角色在不同状态下会有不同的动作,这些动作在引擎里相当于一段段的动画片段.当导入模型资源的时候,连同模型动画都会一并导入到引擎中.开发 ...

  9. Beat &#39;Em Up Game Starter Kit (横版格斗游戏) cocos2d-x游戏源代码

    浓缩精华.专注战斗! 游戏的本质是什么?界面?养成?NoNo!    游戏来源于对实战和比赛的模拟,所以它的本源就是对抗.就是战斗! 是挥洒热血的一种方式! 一个游戏最复杂最难做的是什么?UI?商城? ...

随机推荐

  1. jsp导出excel

    很多时候,我们都知道在java项目里面采用poi来导出excel很方便,但是如果你的项目采用的是jsp你可以用更简单的方法来导出.首先你要在顶部引入:<jsp:directive.page im ...

  2. .net类库中和数据库相关的

    System.Data.SqlTypes SqlDbType 枚举类型 Specifies SQL Server-specific data type of a field, property, fo ...

  3. 《OD大数据实战》HBase入门实战

    官方参考文档:http://abloz.com/hbase/book.html#shell_tricks 1.2.3. Shell 练习 用shell连接你的HBase $ ./bin/hbase s ...

  4. Jenkins+Maven+Git搭建持续集成和自动化部署的配置手记

    前言    持续集成这个概念已经成为软件开发的主流,可以更频繁的进行测试,尽早发现问题并提示.自动化部署就更不用说了,可以加快部署速度,并可以有效减少人为操作的失误.之前一直没有把这个做起来,最近的新 ...

  5. js控制div是否显示

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  6. Tomcat,Jboss,Glassfish等web容器比较选型

    概述 Web容器是一种服务调用的规范,J2EE运用了大量的容器和组件技术来构建分层的企业应用.在J2EE规范中,相应的有WEB Container和EJB Container等. Web容器给处于其中 ...

  7. HDU 2084 数塔

    没什么好说的,这是我学DP的第一道题目. //#define LOCAL #include <iostream> #include <cstdio> #include < ...

  8. win32窗口机制之CreateWindow

    CreateWindow     函数功能:该函数创建一个重叠式窗口.弹出式窗口或子窗口.它指定窗口类,窗口标题,窗口   风格,以及窗口的初始位置及大小(可选的).该函数也指定该窗口的父窗口或所属窗 ...

  9. 报错:对象必须实现 IConvertible;以分隔符进行分割链接concat_ws的使用方法;mysql数据类型转换cast,convert

    错误故障,mysql  服务器上用 concat_ws 函数,连接了一串数字,最后 服务器返回的字段就变成了一个 byte ,而我们想要的类型是  string 类型,那么转换的时候,就报错了. 正确 ...

  10. hadoop数据容易出现错误的地方

    最近在搞关于数据分析的项目,做了一点总结. 下图是系统的数据流向.容易出现错误的地方.1.数据进入hadoop仓库有四种来源,这四种是最基本的数据,简称ods,original data source ...