北大侠客行MUD论坛

 找回密码
 注册
搜索
热搜: 新手 wiki 升级
楼主: hijacker

【梦话连篇】第四辑:灵台方寸,斜月三星——论心跳

[复制链接]
发表于 2013-7-31 23:28:10 | 显示全部楼层
好复杂,避免指令之间产生间隔其实可以用to alias
北大侠客行Mud(pkuxkx.net),最好的中文Mud游戏!
发表于 2013-7-31 23:34:14 | 显示全部楼层
每个心跳节点发生的事件:食物饮水的减少、精神气血的自然回复、busy和其它异常状态结束的判定、晕倒的判定
北大侠客行Mud(pkuxkx.net),最好的中文Mud游戏!
 楼主| 发表于 2013-8-1 00:17:15 | 显示全部楼层
好复杂,避免指令之间产生间隔其实可以用to alias
ftd 发表于 2013-7-31 11:28 PM



    是的,good idea
北大侠客行Mud(pkuxkx.net),最好的中文Mud游戏!
发表于 2013-8-1 11:44:19 | 显示全部楼层

  1. // 这是书剑打坐命令主函数的一部分:
  2.         msg = SKILL_D(force)->exercise_msg(me);
  3.         if (!msg || undefinedp(msg["start_my_msg"]))
  4.                 write("你坐下来运气用功,一股内息开始在体内流动。\n");
  5.         else
  6.                 write(msg["start_my_msg"]);
  7.         me->set_temp("pending/exercise", 1);
  8.         me->set_temp("exercise_cost", exercise_cost);
  9.         if (!msg || undefinedp(msg["start_other_msg"]))
  10.                 tell_room(environment(me),
  11.                         me->name() + "盘膝坐下,开始运功打坐。\n", ({ me }));
  12.         else
  13.                 tell_room(environment(me),
  14.                         msg["start_other_msg"], ({ me }));
  15.         me->start_busy((: exercising :), (:halt_exercise:));   //这里开始打坐过程,通过exercising的返回值来看是否继续start_busy.
  16.                                                                                     //halt_exerciset, 是halt的时候调用的。

  17. //下面是exercising函数:
  18. int exercising(object me)
  19. {
  20.         string force;
  21.         mapping msg;
  22.         int exercise_cost = (int)me->query_temp("exercise_cost");                     //你dazuo花的气血;         
  23.         int neili_gain = 1 + (int)me->query_skill("force") / 10                                      //本次打坐所能获得的内力,和北侠一样,是enable/10;

  24. //        int max = (me->query_skill("force") * me->query("con")*2/3) + (me->query_skill("beiming-shengong", 1)*20);  
  25. //if players wanna get max_neili after force*10, the only way is drugs, quests and age :)
  26. // yes, add some max_neili each year they grow up :)
  27. // yuj please fix it if i made any mistake :)
  28.         int max = me->query_skill("force")*8 + me->query("combat_exp")/1000;
  29.         if (neili_gain > exercise_cost) neili_gain = exercise_cost;                            //如果内力增加值>dazuo所花气血,内力增加值=dazuo所花气血
  30.         me->receive_damage("qi", neili_gain);                                                      //扣掉dazuo所花气血
  31.         me->add("neili", neili_gain);                                                                    //内力增加
  32.         me->set_temp("exercise_cost", exercise_cost -= neili_gain);                     //重新计算dazuo所花气血,扣掉之前的内力增加值
  33.         force = me->query_skill_mapped("force");
  34.         if (force) msg = SKILL_D(force)->exercise_msg(me);
  35.         if (exercise_cost > 0) {                                                                           //判断dazuo气血,大于0则继续busy
  36.                 if (msg && !undefinedp(msg["exec_my_msg"]))
  37.                         tell_object(me, msg["exec_my_msg"]);
  38.                 if (!random(3) && msg && !undefinedp(msg["exec_other_msg"]))
  39.                         tell_room(environment(me), msg["exec_other_msg"], ({me}));
  40.                 return 1;
  41.         }                                                                                                           //判断dazuo气血,不大于0则结束busy,结束dazuo


  42. //下面是结束dazuo

  43.         me->delete_temp("pending/exercise");
  44.         if (!msg || undefinedp(msg["end_my_msg"]))
  45.                 tell_object(me, "你运功完毕,站了起来。\n");
  46.         else
  47.                 tell_object(me, msg["end_my_msg"]);
  48.         if (!msg || undefinedp(msg["end_other_msg"]))
  49.                 tell_room(environment(me),
  50.                         me->name()+"运功完毕,站了起来。\n", ({me}));
  51.         else
  52.                 tell_room(environment(me),
  53.                         msg["end_other_msg"], ({me}));
  54.         if (me->query("neili") < me->query("max_neili") * 2)
  55.                 return 0;
  56.         if (me->query("max_neili") >= max){
  57.                 tell_object(me, "你的内力修为已经无法靠打坐来提升了。\n");
  58.                 me->set("neili", me->query("max_neili") * 2);
  59.                 return 0;
  60.                 }
  61.         me->set("neili", me->add("max_neili", 1));
  62.         tell_object(me, "你的内力修为增加了!\n");
  63.         return 0;
  64. }

复制代码


1)从上面我们可以看出,打坐内功有效等级/10的整数倍都很高效:1)有网络延迟时,dazuo多倍会好点,2)网络良好,还怕超过内力上限2倍多的浪费,dazuo一倍好。
因为dazuo的恢复时start_busy来控制的,而start_busy又调用set_heart_beat(),所以,假设系统的心率是齐的,楼主说的dazuo那部分应该有道理。

2)至于爬塔,我觉得主要有两个方面:你的网络延时和NPC的心跳。
见面就kill的NPC应该是在init()定义了auto_kill, 即见面就杀,但是perform通过一个叫chat()的函数控制,通过参数chat_combat_msg 100拉设置100%每个心跳发perform。
所以,你的网络延迟很高,肯定被先手,你的网络延迟够好的话,基本就是拼人品了。看你的perform命令是否先于npc的心跳。

3)关于指令堆积,应该和心跳没有关系。
系统判断你单位时间内输入的指令数量大于单位时间最大许可指令数量,给你警告,屏蔽指令而已。
北大侠客行Mud(pkuxkx.net),最好的中文Mud游戏!
发表于 2013-8-1 11:48:09 | 显示全部楼层
回复 2# hijacker

按照LZ说的, 是不是应该这样:
这是 tt++ 脚本,
#alias {kill} {
        #action {你运功完毕,深深吸了口气,站了起来。} {
                #send kill %0;
                perform sword.chan;
                #delay {1} {
                        perform dodge.zong;
                        #ticker {chan} {perform sword.chan} {2};
                };
                #unaction {你运功完毕,深深吸了口气,站了起来。}
        } {1};
        yun powerup;
        dazuo 10;
};
北大侠客行Mud(pkuxkx.net),最好的中文Mud游戏!
 楼主| 发表于 2013-8-1 18:50:56 | 显示全部楼层
回复 24# yyahoo


    凡是我想到的网络因素,都写在文里了。。。那种好几百ms延迟的破网络,神仙也搞不定
北大侠客行Mud(pkuxkx.net),最好的中文Mud游戏!
 楼主| 发表于 2013-8-1 18:58:46 | 显示全部楼层
回复 26# zues


    公开揣测源代码太危险了
北大侠客行Mud(pkuxkx.net),最好的中文Mud游戏!
发表于 2013-8-2 08:20:26 | 显示全部楼层
我来砸个场子,最讨厌一倍基数打坐刷屏了
不过要是综合了噩梦休息狂欢周和特技等特殊情况机器人要发我一份啊
北大侠客行Mud(pkuxkx.net),最好的中文Mud游戏!
发表于 2014-3-1 16:57:52 | 显示全部楼层
新手认真学习前辈神贴。
北大侠客行Mud(pkuxkx.net),最好的中文Mud游戏!
发表于 2014-3-1 17:56:52 | 显示全部楼层
这么老的帖子啊
北大侠客行Mud(pkuxkx.net),最好的中文Mud游戏!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|北大侠客行MUD ( 京ICP备16065414号-1 )

GMT+8, 2024-11-16 09:52 PM , Processed in 0.012523 second(s), 13 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表