一个好的接口是尽可能让更多实用的方法进行整理封装,要记住的是不常用的方法和类最好不好封装到接口中,因为那样会造成本身的困惑。基础模块中并没有太多封装,甚至连一个类的封装也没有,而是一些很常用的工具方法,而这些工具方法在整个客户端的设计中是必须的,所以才进入了基础模块。那么,就让我们看看客户端基础的一些方法都有哪些吧。

CODE

文件util.h

/**
* PAP Engine ( -- )
* $Id util.h
* @link -- for the canonical source repository
* @copyright Copyright (c) 2013-2014 viticm( viticm@126.com )
* @license
* @user viticm<viticm@126.com/viticm.ti@gmail.com>
* @date 2014-3-18 15:33:08
* @uses vengine base util functions
*/
#ifndef VENGINE_BASE_UTIL_H_
#define VENGINE_BASE_UTIL_H_ #include "vengine/config.h"
#include "vengine/math/base.h" #define PI (3.1415926535)
#define FLOATMIN (1.0E-9) namespace vengine_base { namespace util { VENGINE_API void savelog(const char* format , ...); //将字符串按照关键字分割
VENGINE_API int32_t convertstring_tovector(const char* str,
std::vector<STRING>& save,
const char* key = "\\/",
bool one_ofkey = true,
bool ignoreempty = true); //取得两点间的距离
VENGINE_API float getdistance(
const vengine_math::base::twofloat_vector_t& position1,
const vengine_math::base::twofloat_vector_t& position2);
VENGINE_API float getdistance(
const vengine_math::base::threefloat_vector_t& position1,
const vengine_math::base::threefloat_vector_t& position2); //取得两点间的距离平方
VENGINE_API float get_squaredistance(
const vengine_math::base::twofloat_vector_t& position1,
const vengine_math::base::twofloat_vector_t& position2); VENGINE_API float get_squaredistance(
const vengine_math::base::threefloat_vector_t& position1,
const vengine_math::base::threefloat_vector_t& position2); template<class T, class U, class V>
inline void clamp(T &v, const U &min, const V &max) {
v = (v < min) ? min : v;
v = (v > max) ? max : v;
} //求两个向量的点积
inline float get_dotproduct(
const vengine_math::base::twofloat_vector_t& vector1,
const vengine_math::base::twofloat_vector_t& vector2) {
return vector1.x * vector2.x + vector1.y * vector2.y;
} /*
|
| 取得从Pos1到Pos2的矢量相对于Y轴的旋转角度, 以z轴为0度
|
| ->x
| o pos1
| | |\
| z v | \
| | \
| | \
| | o pos2
|
| Return [0 ~ 2pi)
*/ VENGINE_API float get_Yangle(
const vengine_math::base::twofloat_vector_t& position1,
const vengine_math::base::twofloat_vector_t& position2); /*
|
| 取得从Pos1与Pos2之间的中心点
|
| ->x
| o pos2
| | /
| z v o <- This point!
| /
| o
| pos1
|
*/
VENGINE_API vengine_math::base::threefloat_vector_t getcenter(
const vengine_math::base::threefloat_vector_t& position1,
const vengine_math::base::threefloat_vector_t& position2); /*
|
| 取得v1相对于从Pos1与Pos2之间直线的镜像点
|
| ->x
| o pos2
| | v1 /
| z v \ /
| \/
| / \
| o \
| pos1 v2 <- This point!
|
*/
VENGINE_API vengine_math::base::twofloat_vector_t getreflect(
const vengine_math::base::twofloat_vector_t& position1,
const vengine_math::base::twofloat_vector_t& position2,
const vengine_math::base::twofloat_vector_t& vector1); //从内存中读取一行文本(相当于fgets)
VENGINE_API const char* getline_frommemory(char* buffer,
int32_t size,
const char* memory,
const char* deadend); VENGINE_API bool sheckstring_valid(const char* str); /*
| 使目标点根据方向轴旋转,返回旋转后的坐标。
|
| position 要旋转的目标点坐标
| axis 以原点为起点的矢量方向轴
| angle 旋转的角度
|
| 注:axis会被单位化,变以原点为起始点的矢量方向。如果想根据任意轴做旋转,
| 需要先将目标点做相应的平移,调用该函数旋转后,再平移回去即可。
|
*/
VENGINE_API vengine_math::base::threefloat_vector_t rotateangle(
const vengine_math::base::threefloat_vector_t& position,
const vengine_math::base::threefloat_vector_t& axis,
float angle); /*
| hermite曲线差值算法。曲线被划分为150段,返回所需段数的2D坐标位置
|
| x1,y1,x2,y2 曲线端点,最好数值限制在1000以内,否侧运算时会超出运算范围
| xr1,yr1,xr2,yr2 曲线两参考向量, 最好限制在1000以内
| currentiter 当前段数,值限定在150以内。
*/
//win32 POINT
POINT hermitecurve(int32_t x1,
int32_t y1,
int32_t x2,
int32_t y2,
int32_t xr1,
int32_t yr1,
int32_t xr2,
int32_t yr2,
int32_t currentiter); //同 hermitecurve
POINT beziercurve(int32_t x1,
int32_t y1,
int32_t x2,
int32_t y2,
int32_t xr1,
int32_t yr1,
int32_t xr2,
int32_t yr2,
int32_t currentiter); }; //namespace util }; //namespace vengine_base #endif //VENGINE_BASE_UTIL_H_

总结

这里没有太多复杂的方法应用,仅仅是一个记录日志的接口和一些常用的数学算法的封装,对于一个客户端(3D类型)来说这些方法基本上都是需要用到的。在这里还是强调那一点,就是必须用到的方法才加入基本模块,如果不是类的封装一般就封装在工具集合中,有些朋友更喜欢将工具集合叫做方法工厂(functions factory)。无论怎样命名,你要清楚的知道你要在什么地方会用到,以及它自身的作用范围。好了,基础模块的方法也没有什么特别需要去说明的,至于数学算法大家可以上网上去搜集资料了解一下,在这里我就不具体解释其实现的过程了。下节将为大家讲述math(数学)模块,其实天龙八部/武侠世界参考了比较好的ogre的设计,我们下节可以看到它怎样去扩展一些数学相关的数据类型的。

MMORPG大型游戏设计与开发(客户端架构 part2 of vegine)的更多相关文章

  1. MMORPG大型游戏设计与开发(客户端架构 part8 of vegine)

    脚本模块是游戏设计中争论比较多的话题,那是因为作为脚本本身所带来的利弊.其实这都无关紧要,取舍是人必须学会的一项技能,如果你不会取舍那么就让趋势给你一个满意的答复.自从魔兽世界以及传奇(世界)问世以来 ...

  2. MMORPG大型游戏设计与开发(概述)updated

    1.定义 MMORPG,是英文Massive(或Massively)Multiplayer Online Role-PlayingGame的缩写,即大型多人在线角色扮演游戏. 2.技术与知识 在这系列 ...

  3. MMORPG大型游戏设计与开发(UI SYSTEM SHOW)

    接下来一段时间,这些文件可能不再更新,期间我会学习和掌握一些前端知识.虽然我非常欣赏剑侠网络版叁和九阴真经的画面,但是那是一个庞大的游戏引擎,一般人是无法窥伺的,除非你是天才而且要拥有机器毫无中断的毅 ...

  4. MMORPG大型游戏设计与开发(服务器 游戏场景 核心详述)

    核心这个词来的是多么的高深,可能我们也因为这个字眼望而却步,也就很难去掌握这部分的知识.之所以将核心放在最前面讲解,也可以看出它真的很重要,希望朋友们不会错过这个一直以来让大家不熟悉的知识,同我一起进 ...

  5. MMORPG大型游戏设计与开发(游戏服务器 游戏场景 概述 updated)

    我们在玩游戏的时候,我们进入游戏后第一眼往往都是看到游戏世界中的场景,当然除了个别例外,因为那些游戏将游戏场景隐藏了起来,如文字游戏中的地点一样.既然我们接触了游戏世界的核心,那么作为核心的场景又包括 ...

  6. MMORPG大型游戏设计与开发(客户端架构 part12 of vegine)

    在游戏中的交互过程中输入是一个必不可少的过程,比如登陆的时候需要用户输入用户名与密码,就算是单机游戏很多时候也要求用户输入一个用户名作为存档的依据.网络游戏中没有了输入,只用鼠标来交互是不切实际的,因 ...

  7. MMORPG大型游戏设计与开发(客户端架构 part2 of vgui)

    这一节我将讲解vgui的基础系统部分,也是该库提供给外部使用的一些重要接口.作为UI部分比较重要的部分,该节有着至关重要的部分,如果没有看到上一节内容,请留意下面的连接.我们现在可以猜想一下在客户端U ...

  8. MMORPG大型游戏设计与开发(客户端架构 part16 of vegine)

    由于近来比较忙碌和有些困倦的原因,所以关于这部分的文章没有及时更新,一句话:让朋友们久等了!今天所讲的是客户端vengine(微引擎)中最后一个部分,就像上节所说,这一部分的内容比较多.可能有些朋友看 ...

  9. MMORPG大型游戏设计与开发(客户端架构 part9 of vegine)

    时间在人们的生活中是多么重要的东西,如果打乱了时间,不知道这个时间会成什么样子.在客户端中,自然也有时间模块,因为不同的时间可能会处理不同的事情,特别是在追求高度自由化的同时,时间也成为了一个很重要的 ...

  10. MMORPG大型游戏设计与开发(客户端架构)

    首先为所有等待的朋友说一声歉意,实在让大家等的太久.客户端的设计本来就是一个大的工程,而且工作的关系,也没有太多时间在这方面做研究.不过在私下有空的时间,我还是继续着这方面的研究,很遗憾没有用期望的o ...

随机推荐

  1. Nodejs与ES6系列1:变量声明

    1.声明变量 在JS当中一个变量的作用域(scope)是程序中定义这个变量的区域.变量分为两类,全局(global)的和局部的.其中全局变量的作用域是全局性的,即在JavaScript代码中,它处处都 ...

  2. $('div a') 与$('div>a'),.div+.div2与.div~.div2

    $('div a'):div标签下所有层次a元素的jquery对象 $('div>a'):div标签下子元素层次a元素的jquery对象 <body> <div class=' ...

  3. BookBlock - 效果非常真实的书本翻页预览

    这个名为 BookBlock 的图片预览效果是一个书展示或网上书店的概念,已全屏打开3D页面导航网格的形式显示图书的详细信息.我们可以打开书预览的摘录,其中有一些细节的网格.对于图书预览,我们在使用 ...

  4. transform:rotate在手机上显示有锯齿的解决方案大全

    先来个兼容性说明,洗洗脑: div{transform:rotate(7deg);-ms-transform:rotate(7deg); /* IE 9 */-moz-transform:rotate ...

  5. angularjs封装bootstrap官网的时间插件datetimepicker

    背景:angular与jquery类库的协作 第三方类库中,不得不提的是大名鼎鼎的jquery,现在基本上已经是国内web开发的必修工具了.它灵活的dom操作,让很多web开发人员欲罢不能.再加上已经 ...

  6. 【初探HTML本相】道之真谛不过自然,html标签脱俗还真

    前言 须弥般若有无空,阴阳道化真虚同:洗尽前恩本非相,还吾面目下九重. 咳咳,其实老夫对佛教文化有点点研究啦,说以我们这里来了一点很有哲理的东西,因为我这里准备干一件很戳的事情,我准备来看看我们的ht ...

  7. div水平居中

    1.先给它外层的div定位并left:position:absolute;left:50%; 2.获取当前元素div的宽度,并除以2 3.改变它的css:margin-left:-(获取当前元素div ...

  8. Autodesk hackathon 技术参考资料

    Autodesk 首届黑客马拉松(hackathon )将于6月14号在上海举行,在这次活动中,推荐您使用的技术有ReCap 360 photo照片建模技术和Autodesk 360 viewer通用 ...

  9. Hadoop出现 native snappy library not available: SnappyCompressor has not been loaded的解决办法

    我目前测试环境是Hadoop 2.7.1, 搭建群集之后经常出现错误“native snappy library not available: SnappyCompressor has not bee ...

  10. 通知 - NSNotificationCenter

    1.每一个应用程序都有一个通知中心(NSNotificationCenter)实例,专门负责协助不同对象之间的消息通信: 2.任何一个对象都可以向通知中心发布通知(NSNotification), 描 ...