原作者: ayase

 

8-27修正
修复首次使用后的红字
不需要额外进数据库导入计分表,这lua全自动生成

--------------------------------------------------------------
惯例写在前面:

写这玩意其实学习性更大于目的性。。
= =研究了两天晚上写的我人参中滴第一个lua脚本,居然还真给我写出来了,好感动
由于写代码的基础基本是零 所以碰了N+N次壁
什么函数字母大小写还要区分  -- 闹哪样啊喂 因为这个原因我试了半个多钟才发现问题所在
什么函数命名 基本我感觉除了我自己能看得懂之外没别人能看得懂的了  我自己都感觉无法直视了,总之乱七八糟的 ,各种中西合并,英文+拼音混搭,反正跟规范完全不搭边,嘛,对于我这小白来说反正能用就得了。。
对于语句优化。。。  反正没优化过 而且有大量重复或者完全没必要的语句  所以执行效率并不是说很好
嘛  反正自己用也不在意了。。

都是看别人的脚本(item_up.lua)才会了这么点皮毛。。
然后不得不说不知道为啥我手头的item_up.lua 只有这么个文件 配套的sql居然没有
我这是在哪扒的脚本没扒干净啊
最后看一晚上这个脚本终于算是还原出来数据库的表了 在这么纠结的情况下唯一庆幸的是因为这个lua是我基本上是看懂了。。
然后对应lua的执行过程有了点了解了算是
但是还有好多不懂的说。。

= =  废话这么多  进正题吧。。

解压后放到服务端 lua_Scripts 文件夹下即可

使用之前首先用文本(最好是nptepad++之类的高级文本编辑工具,否则可能会导致游戏乱码)打开该lua 
修改这几个参数
local ItemEntry=70008  --积分宝石
local jf_entry=70002  --要领取的物品id
local jf_mins=10   --每多少分钟领取

依次分别是 积分宝石(即点击后打开下面的面板),在线时间可以领取的物品id,每多少分钟可以领取一个

lua 脚本 null_数据库

 

lua 脚本 null_lua_02

 

lua 脚本 null_lua 脚本 null_03

 

lua 脚本 null_lua 脚本 null_04




lua 脚本 null_数据库_05

lua 脚本 null_lua 脚本 null_06

1  print (">> loading online_jf.lua")
 2 
 3 
 4 local ItemEntry=70008 --用于使用后查看积分并兑换的物品entry。 ps 其实可以整合到什么超级炉石那里的,所选用的物品必须带技能的能使用的。
 5 local jf_entry=70002 --代表积分的物品可以叫某某货币之类的,本来想直接加在数据库值然后读取的 不过兑换东西的时候太麻烦,所以还是做成了物品容易用于兑换。
 6 local jf_mins=10 --设置每多少分钟得到1点积分。
 7 
 8 local mins=nil
 9 local jf=nil    
10 local jf_count=nil
11 local inGameTime=nil
12 local playergid=nil
13 local jf_DBtime=nil
14 local jf_ingametime=nil
15     
16 local function online_jf(event, player, item, target)    
17     player:MoveTo(0,player:GetX(),player:GetY(),player:GetZ()+0.01)
18     --player:GossipComplete()
19     player:GossipClearMenu()    
20     playergid=item:GetOwnerGUID()    
21     jf_DBtime=CharDBQuery("SELECT * FROM characters_jf WHERE guid="..playergid..";")
22     if (jf_DBtime==nil) then    
23         CharDBExecute("insert into characters_jf (guid,jf_time,jf) VALUES ("..playergid..",0,0);")        
24         player:SendBroadcastMessage("首次领取,初始化数据,请再次点击使用。")        
25     else
26     inGameTime=player:GetTotalPlayedTime()
27     jf_ingametime=math.modf(inGameTime-jf_DBtime:GetUInt32(1))
28     jf=math.modf(jf_ingametime/60/jf_mins)
29     mins=math.modf(jf_ingametime/60)    
30     jf_count=player:GetItemCount(jf_entry)        
31         if(jf_count==nil) then 
32             jf_count=0 
33         end                
34     player:GossipComplete()                                        
35     player:GossipMenuAddItem(0,"您当前拥有"..GetItemLink(jf_entry).." x "..jf_count.."。\n\n累计共领取"..GetItemLink(jf_entry).." x "..jf_DBtime:GetUInt32(2).."\n\n累计未兑换的在线时间: "..mins.."分钟\n\n每在线"..jf_mins.."分钟可以兑换"..GetItemLink(jf_entry).." x 1  \n\n你当前一共可以兑换"..GetItemLink(jf_entry).." x "..jf.." ",1,1)
36     player:GossipMenuAddItem(1,"点击确定兑换",1,1)
37     player:GossipSendMenu(1, item)    
38     --player:GossipClearMenu()
39     --player:GossipComplete()
40     end        
41 end
42 
43 local function timetojf(event, player, item, target)
44     if (jf==0) then
45           player:SendBroadcastMessage("兑换失败,累计在线时间少于"..jf_mins.."分钟。")
46     else
47      jf=math.modf(jf_ingametime/60/jf_mins)
48       player:AddItem(jf_entry, jf)        
49       playergid=item:GetOwnerGUID()        
50       CharDBExecute("update characters_jf set jf_time=jf_time+"..jf_ingametime..",jf=jf+"..jf.." where guid="..playergid..";")
51       player:SendBroadcastMessage("成功兑换"..GetItemLink(jf_entry).." x " ..jf)
52       player:GossipComplete()
53       player:GossipClearMenu()
54     end
55      
56 end
57 
58 
59     CharDBExecute([[    
60 CREATE TABLE IF NOT EXISTS `characters_jf` (
61   `guid` int(10) NOT NULL,
62   `jf_time` int(10) NOT NULL DEFAULT '0',
63   `jf` int(10) NOT NULL DEFAULT '0',
64   PRIMARY KEY (`guid`)
65 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
66     ]])
67 
68 
69 RegisterItemEvent(ItemEntry, 2, online_jf)
70 RegisterItemGossipEvent(ItemEntry, 2, timetojf)


查看代码