实时查看iOS版本手Q的log

  • 将手机连接至Mac电脑,并打开手机QQ。
  • 脚本层使用BK.Script.logToConsole = 1打开远程输出log开关
  • 打开Mac电脑的“控制台”程序可以使用在launchpad中直接搜索 "控制台" 7.1.开发调试log提取  - 图1
  • 运行游戏后,在"控制台"过滤"brick"关键字则可以实时查看log 7.1.开发调试log提取  - 图2

    除此外,ios版本的手Q可以通过 左抽屉-设置-日志上报 将日志提取出来

实时查看Andoird版本手Q的log

android版本手Q可通过设备连接Android Studio 进行日志查看。在此不赘述。

Xcode工程下使用Safari远程调试游戏

1. 打开电脑端Safari的开发者模式

【设置】->【高级】-> 勾选『在“菜单栏显示“开发”菜单』

safari-develop

2. 打开模拟器/真机的开发者模式

【设置】->【Safari】->【高级】-> 打开『Web检查器』

ios-inspector

3. 在模拟器/真机运行游戏工程(真机连接USB)

运行游戏后,

game-running

打开Safari的开发菜单,可以看到有模拟器/真机设备列出。(如果没有设备列出,请检查前面步骤的设置后重启Safari,或重新运行游戏工程)

develop-menu

在模拟器(Simulator)的展开菜单中选择工程(PublicBrickEngineGame)对应的JSContext,就会出现调试面板

web-inspector

4. 断点调试

在Debugger选项卡中,从左侧源文件列表双击打开文件,在打开的文件左侧点击行号可以添加断点。

breakpoint

代码执行到断点位置游戏会暂停运行,在左侧可以看到函数调用栈,点击右上角打开作用域面板开关可以看到断点所在作用域内的局部变量和所有全局变量。

scope

通过左上方的控制按钮可以控制单步调试。将鼠标悬浮在变量上,可以看到变量的具体信息,在下方输入框可以直接输入脚本执行,甚至修改变量的值

variable

可以通过console.log打印变量查看变量属性,console.log会输出到Safari的控制台,BK.Script.log会输出到XCode控制台。(注意不要操作非js对象如console.log(BK),否则会出现未定义错误)

console

5. js异常

当js代码发生异常时,控制台会打印出具体的错误信息,可以定位对应文件的错误行。

error

原文: https://hudong.qq.com/docs/engine/debug/intro.html