AI中的事件与场景中的事件大致相同,都是由特定的条件触发的。只不过AI的事件与其他事件不同的是,对于AI的事件往往是根据不同的AI类型,和动态的触发条件下才产生的。其实不管AI多么智能,它对应的触发条件在游戏中其实并不是很多,不过触发的条件按照各种组合就形成表现类型不同的AI而已。

游戏截图

事件

1、条件(condition)

1 设置触发事件的条件(set condition)

设置可以触发该事件的条件,一般只是一个枚举标记。

2 检查触发事件的条件(check condition)

根据当前的事件,以及自身的对象指针,判断事件是否被触发。触发这些事件的条件有自身与目标血量的百分比,超过一定时间,随机返回,还包括自身死亡、目标死亡、回到原点、转到战斗、转到休闲(空闲动作)。

3 设置条件数据(set value)

血量百分比、超时时间等数据。

2、动作(action)

1 设置行为(set action)

设置事件对应的行为动作。

2 执行行为(run action)

执行事件的行为动作,调用相应的接口进行处理。这些动作包括逃跑、原地寻求帮助、逃向盟友、自杀、执行脚本。

3 设置逃跑的几率(set escape chance)

用于判断是否触发逃跑。

4 设置寻求帮助的范围(set call help range)

只有在帮助范围类的友方对象才会被呼唤。

5 设置动作需要执行的脚本(set script name)

如果事件执行触发了执行脚本,设置了对应的脚本文件则会在执行动作的时候调用到。

3、事件(event)

1 初始化(init)

初始化对应的事件动作,初始化事件触发条件的方式(或与),设置事件触发的次数(1次性,或者按照CD重复触发)。

2 设置CD的帧间隔(set cd frame)

其实这就是设置设置CD事件执行的时间间隔。

3 添加条件以及对应的数据(add condition)

增加事件触发的一个条件以及其对应的数据。

4 事件检查(check event)

检查事件是否可以正常的触发,是对条件列表中的条件进行判断。

5 触发事件(fire event)

根据自身的指针,以及事件的索引,以及当前的触发条件,来检查是否触发对应的行为。

6 执行事件(run event)

主要是执行事件对应的动作行为。

算法(枚举算法)

1、判断一个数是否能被3、5、7整除

code.

#include <stdio.h>
#include <inttypes.h> int32_t main(int32_t argc, char *argv[]) {
int32_t n;
int32_t c1, c2, c3;
printf("please input a int number: ");
scanf("%d", &n);
c1 = == n % ;
c2 = == n % ;
c3 = == n % ;
switch ((c1 << ) + (c2 << ) + c3) {
case : {
printf("%d can't be divided with 3 or 5 or 7", n);
break;
}
case : {
printf("%d just can be divided by 7", n);
break;
}
case : {
printf("%d just can be divided by 5", n);
break;
}
case : {
printf("%d can be divided with 5 and 7", n);
break;
}
case : {
printf("%d just can be divided by 3", n);
break;
}
case : {
printf("%d can be divided with 3 and 7", n);
break;
}
case : {
printf("%d can be divided with 3 and 5", n);
break;
}
case : {
printf("%d can be divided with 3 and 5 and 7", n);
break;
}
default:
break;
}
printf("\n");
return ;
}

result.

2、百元买百鸡

code.

#include <stdio.h>
#include <inttypes.h> const int32_t kCockPrice = ; //一只公鸡的价格
const int32_t kHenPrice = ; //一只母鸡的价格
const int32_t kChicks = ; //一元钱能买小鸡的数量 void scheme(int32_t money, int32_t chooks); //计算并输出购买方案 int32_t main(int32_t argc, char *argv[]) {
int32_t money = ; //钱的总数
int32_t chooks = ; //鸡的总数
printf("the way is: \n");
scheme(money, chooks);
return ;
} void scheme(int32_t money, int32_t chooks) {
int32_t cockmax = money / kCockPrice;
int32_t henmax = money / kHenPrice;
int32_t chickmax = chooks;
int32_t cock, hen, chick; //公鸡、母鸡、小鸡的数量
for (cock = ; cock < cockmax; ++cock) { //枚举公鸡可能的数量
for (hen = ; hen < henmax; ++hen) { //母鸡的数量枚举
for (chick = ; chick < chickmax; ++chick) { //小鸡可能的数量枚举
if ( == chick % kChicks &&
cock + hen + chick == chooks &&
kCockPrice * cock + kHenPrice * hen + chick / kChicks == money) {
printf("cock: %2d, hen: %2d, chick: %2d\n", cock, hen, chick);
}
}
} //for
} //for
}

result.

MMORPG大型游戏设计与开发(服务器 AI 事件)的更多相关文章

  1. MMORPG大型游戏设计与开发(服务器 AI 控制器)

    上一篇我们说了基础接口的组成,想必大家对AI中的基础方法有了一定的了解,而基础接口只能一个通用的,要实现不同的类别还需子类中实现,这就形成了玩家.主动.被动.木桩这些类型.不同类型的AI需要有一个统一 ...

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

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

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

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

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

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

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

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

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

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

  7. MMORPG大型游戏设计与开发(服务器 AI 基础接口)

    一个模块都往往需要统一的接口支持,特别是对于非常大型的模块,基础结构的统一性非常重要,它往往决定了其扩展对象的通用性.昨天说了AI的基本概述以及组成,作为与场景模块中核心一样重要的地位,基础部分的设计 ...

  8. MMORPG大型游戏设计与开发(服务器 AI 概述)

    游戏世界中我们拥有许多对象,常见的就是角色自身以及怪物和NPC,我们可以见到怪物和NPC拥有许多的行为,比如说怪物常常见到敌对的玩家就会攻击一样,又如一些NPC来游戏世界中走来走去,又有些怪物和NPC ...

  9. MMORPG大型游戏设计与开发(服务器 AI 逻辑设定和状态结点)

    人工智能(AI)中往往都会有这么一个问题,那就是我要做什么?我该怎么做?我需要什么?所以这里所谓的智能就是赋予AI对象的判断力,以及它根据判断得到的相应反应.就好比,你去商店买东西,钱够别人才卖给你, ...

随机推荐

  1. 了解HTML列表

    前面的话 从某种意义上讲,不是描述性文本的任何内容都可以认为是列表.人口普查.太阳系.餐馆菜单等都可以表示为一个列表或列表的列表.列表分为无序列表.有序列表和定义列表三种 无序列表 无序列表(unor ...

  2. 剖析AngularJS作用域

    一.概要 在AngularJS中,子作用域(child scope)基本上都要继承自父作用域(parent scope). 但,事无绝对,也有特例,那就是指令中scope设置项为对象时,即scope: ...

  3. chrome控制台模拟hover、focus、active等状态,方便调试

    有时候需要调试一个网页,需要某些元素在hover.focus.active等状态. 比如hover,鼠标放到hover上,然后去控制台中找DOM,鼠标移开的时候元素就不是hover状态了. 此时可以使 ...

  4. redis命令1

    SADD numbers 1 3 5 创建一个名为numbers的intset SADD fruites "apple" "peach" 创建一个hashtab ...

  5. 你真的会玩SQL吗?查询指定节点及其所有父节点的方法

    --查询ID = '009'的所有父节点 ' ;WITH T AS ( SELECT ID , PID , NAME FROM TB WHERE ID = @ID UNION ALL SELECT A ...

  6. JavaScript实现图片轮播组件

    效果: 自动循环播放图片,下方有按钮可以切换到对应图片. 添加一个动画来实现图片切换. 鼠标停在图片上时,轮播停止,出现左右两个箭头,点击可以切换图片. 鼠标移开图片区域时,从当前位置继续轮播. 提供 ...

  7. 用python实现最长公共子序列算法(找到所有最长公共子串)

    软件安全的一个小实验,正好复习一下LCS的写法. 实现LCS的算法和算法导论上的方式基本一致,都是先建好两个表,一个存储在(i,j)处当前最长公共子序列长度,另一个存储在(i,j)处的回溯方向. 相对 ...

  8. C# 系统托盘图标

    C# 系统托盘图标 WPF NotifyIcon 资料 网址: http://www.codeproject.com/Articles/36468/WPF-NotifyIcon http://www. ...

  9. afxcomctl32.h与afxcomctl32.inl报错

    afxcomctl32.h与afxcomctl32.inl报错 编译公司一个几年前的老项目,是从VC6.0升级到VS2005的. 1.编译时报缺少头文件,于是附件包含目录,于是出现了以下报错: 1&g ...

  10. Java集合-Python数据结构比较

    Java list与Python list相比较 Java List:有序的,可重复的.(有序指的是集合中对象的顺序与添加顺序相同) Python list(列表)是有序的,可变的. Java Lis ...