• 按键公众号 :
按键精灵电脑版
立即下载

软件版本:2014.06
软件大小:22.9M
更新时间:2021-12-03

按键精灵安卓版
立即下载

软件版本:3.7.2
软件大小:46.2M
更新时间:2023-05-10

按键精灵iOS版
立即下载

软件版本:1.8.0
软件大小:29.2M
更新时间:2023-03-21

按键手机助手
立即下载

软件版本:3.8.0
软件大小:262M
更新时间:2023-05-30

快捷导航

登录 后使用快捷导航
没有帐号? 注册

发新话题 回复该主题

[紫猫] [按键手机插件开发]06. 优化按键TracePrint实现打印输出任何数据... [复制链接]

1#
本系列教程目的是让大家掌握Lua基本语法与按键精灵手机版的插件开发制作,丰富按键精灵生态环境,让按键精灵变得更加强大!
本教程中部分知识点参考《Lua程序设计》书籍,有兴趣可以自行购买→传送门
按键精灵手机版插件的开发标准草案请阅读帖子:http://bbs.anjian.com/showtopic-697779-1.aspx
紫猫学院也有提供Lua插件开发的VIP教学服务,有兴趣请咨询紫猫老师QQ345911220或微信zimaoxy

前言
在前面课程中,我们已经详细介绍了Lua的一些语法规则、数据类型和函数用法,本节课我们将开发第一个按键精灵手机班插件函数。按键精灵自带的 TracePrint 在输出查看数组的时候会直接显示unknown,在输出查看文本内容的时候,空格等不可见字符无法被立即察觉到,这些都对我们调试脚本造成不便,所以本节课将通过插件函数来解决这个问题,对应紫猫插件中的zm.TracePrint与zm.VarInfo函数。


插件框架
在开发插件之前,建议大家熟读《按键精灵手机版插件的开发标准草案与简易教程》,本节课将在该插件框架上进行进一步的开发,以下是纯框架例子。



在按键精灵中打印输出插件内部数据
在按键精灵中我们使用TracePrint可以打印输出查看信息,在Lua中我们使用print可以打印输出信息,但是print无法在按键精灵上打印输出,而直接写TracePrint会报错,因为这个TracePrint是按键精灵的命令,并非Lua的命令。所以这里我们要调用按键精灵的LuaAuxLib库里的TracePrint函数实现插件在按键精灵上打印输出数据。但是这个函数有一个局限性,第一个参数是由按键编辑器传入的代码行数,而我们没有办法自动获取代码行号,导致只能输出查看信息,而无法得知这是第几行代码的输出。
为了方便调试脚本,我们先封装一个内部使用的traceprint命令,同时让这个命令在Lua调试环境下使用print函数输出,而在按键精灵调试环境下使用LuaAuxLib.TracePrint打印到按键控制台上。



获取变量详细信息
我们通过自定义的VarInfo函数返回变量的详细信息内容, 方便打印输出, 函数要求支持可变长参数, 并对每一个参数的数据类型, 长度, 内容都进行输出, 如果遇到table数组数据, 则转换json后打印.



在按键精灵中打印输出变量详细信息
上面已经得到了详细的信息数据了,现在我们只要通过LuaAuxLib.TracePrint传入上面函数返回值即可实现打印输出。



整合代码
通过上面介绍,我们已经将功能全部实现,整合入插件框架中,我们将插件保存为zimaoxy.lua,并放到按键精灵手机助手的Plugin目录下,这里注意不要保存成zimao.lua!

  1. local _zimao = {} --这是内部私有table函数
  2. local zimao = {} --这是对外公开table函数
  3. QMPlugin = zimao --通过这行代码, 实现将zimao表中所有函数对外公开

  4. _zimao.version = "20220306" --插件版本号, 方便自己记忆

  5. local function try(block) -- 保护执行函数
  6. local tablejoin = function (...)
  7. local result = {}
  8. for _, t in ipairs({...}) do
  9. if type(t) == "table" then
  10. for k, v in pairs(t) do
  11. if type(k) == "number" then table.insert(result, v)
  12. else result[k] = v end
  13. end
  14. else
  15. table.insert(result, t)
  16. end
  17. end
  18. return result
  19. end

  20. -- get the try function
  21. local try = block[1]
  22. assert(try)

  23. -- get catch and finally functions
  24. local funcs = tablejoin(block[2] or {}, block[3] or {})

  25. -- try to call it
  26. local result_error = {}
  27. local results = {pcall(try)}
  28. if not results[1] then
  29. -- run the catch function
  30. if funcs and funcs.catch then
  31. result_error = {funcs.catch(results[2])}
  32. end
  33. end

  34. -- run the finally function
  35. if funcs and funcs.finally then
  36. local result_fin = {funcs.finally(table.unpack(results))}
  37. if #result_fin > 0 then
  38. return table.unpack(result_fin)
  39. end
  40. end

  41. -- ok?
  42. if results[1] and #results > 1 then
  43. return table.unpack(results, 2, #results)
  44. else
  45. if #result_error > 0 then
  46. return table.unpack(result_error)
  47. else
  48. return nil
  49. end
  50. end
  51. end
  52. local function catch(block) --异常捕获函数
  53. return {catch = block[1]}
  54. end
  55. local function finally(block) --最终必定执行函数
  56. return {finally = block[1]}
  57. end

  58. -- 常用的内部函数, 不加入私有table中, 直接定义使用
  59. local function traceprint(...) --调用按键精灵的调试输出命令
  60. if QMPlugin then -- 在Lua调试环境下, QMPlugin变量的值是我们插件公开table函数值, 而在按键精灵调试运行环境下, 该变量值被替换为nil
  61. print(...)
  62. else
  63. -- 获取可变长参数的第一个参数值
  64. local line = select(1, ...)
  65. -- 如果第一个参数是字符串, 并且符合格式 _数字 , 则判定为行号意思
  66. if type(line) == "string" and line:match("^%_%d+$") then
  67. -- 第一个参数按照格式 _数字: 传入TracePrint中可实现打印行号功能
  68. LuaAuxLib.TracePrint(line .. ":", table.concat({...}, " ", 2, select("#", ...)))
  69. elseif line == ":" and #{...} > 1 then
  70. -- 第一个参数是冒号 : 时, 表示直接打印输出数据
  71. LuaAuxLib.TracePrint(":", table.concat({...}, " ", 2, select("#", ...)))
  72. else
  73. -- 其他的情况下则加上前缀后, 进行正常输出
  74. LuaAuxLib.TracePrint(":","紫猫学院测试插件:", ...)
  75. end
  76. end
  77. end

  78. -- 实现获取变量信息的插件函数, 需对外公开, 所以使用zimao前缀
  79. function zimao.VarInfo(...)
  80. -- 防止无法获取nil参数
  81. local paramCount = select("#", ...)
  82. local varType, printStr, t = "", "", {}
  83. for i = 1, paramCount do
  84. local v = select(i, ...)
  85. try {
  86. function()
  87. varType = type(v)
  88. if varType == "table" then
  89. printStr = "【" .. varType .." " .. tostring(#v) .. "】" .. LuaAuxLib.Encode_GetJsonLib():encode(v)
  90. elseif varType == "number" or varType == "string" then
  91. printStr = "【" .. varType .." " .. tostring(#tostring(v)) .. "】" .. tostring(v)
  92. elseif varType == "boolean" or varType == "null" then
  93. printStr = "【" .. varType .."】" .. tostring(v)
  94. else
  95. printStr = "【" .. varType .."】 未知数据,无法查看!"
  96. end
  97. table.insert( t, #t + 1, printStr )
  98. end,
  99. catch {
  100. function (errors)
  101. -- 下面这个traceprint是我们上面定义过的内部输出命令,注意大小写
  102. traceprint("发生运行时错误!错误代码:VarInfo(),错误信息:", errors)
  103. end
  104. }
  105. }
  106. end
  107. printStr = table.concat( t, ", " )
  108. return printStr
  109. end

  110. -- 实现打印输出变量详细信息数据, 需对外公开
  111. function zimao.TracePrint(...)
  112. -- 通过VarInfo函数获取参数的详细数据信息
  113. local info = zimao.VarInfo(...)
  114. try {
  115. function()
  116. -- 在保护模式下打印输出这个数据内容
  117. traceprint(info)
  118. end,
  119. catch {
  120. function (errors)
  121. traceprint("发生运行时错误!错误代码:TracePrint(),错误信息:", errors)
  122. end
  123. }
  124. }
  125. end
复制代码



按键精灵测试
插件完成后,记得要先自己调试运行测试一遍,检查是否有错误,本次代码测试效果如下图:



【紫猫编程学院】火热招生中

教学涉及按键精灵(电脑版与手机版)、网页、游戏、办公、插件等。

报名咨询QQ: 345911220 微信:zimaoxy

紫猫学院免费教程

加入交流QQ群: 7333555


2#

实现数据可视化

3#

321321

4#

学习学习

5#

马克一下,回来学习

6#

好强

7#

好东西!!!!!







Yeah分享

8#


发新话题 回复该主题