iOS 设备屏幕上实时打印 Log 的小工具

需求

写这个小工具的想法,主要来源于很多团队都会用友盟、TalkingData 等第三方框架做自定义事件统计;不过统计代码加好之后,没有很好的方法来让测试工程师验证一下事件加上了没有,调用次数有没有重复等。

所以写了这个小工具,是一个保持在最前的 UIWindow,可以实时打印 log。

源码地址

 

源码是用 Objective-C 写的,放在 github 上了。

https://github.com/DaiYue/HAMLogOutputWindow

 

用法

 

集成

 

只需把 HAMLogOutputWindow.h、HAMLogOutputWindow.m 两个文件加到工程中。如果您使用友盟或者 TalkingData 做事件统计,也可以加进来 demo 工程中的 HAMStatisticsManager.h 和 HAMStatisticsManager.m。

 

开启

 

启用这个 debug 窗口非常简单,只需一行代码:

 

[[HAMLogOutputWindow sharedInstance] setHidden:NO];

 

您可以把这行代码加到 AppDelegate.m 里,例如:

 

#define SHOW_STATISTICS_DEBUG 1

 

@implementation AppDelegate

 

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

 

#if DEBUG && SHOW_STATISTICS_DEBUG

    [[HAMLogOutputWindow sharedInstance] setHidden:NO];

#endif

 

    return YES;

}

 

不需显示 时把 define 的1改为0即可,也保证了在 release 版本中不会出现。

 

输出和清空 log

 

输出 log:

 

[HAMLogOutputWindow printLog:@"some log"];

 

输出的 log 会滚动显示在 debug 窗口中,末尾会自动添加换行。最新的 log(0.1s 之内)会显示为黄色,之前的会显示为白色。

 

如需清空 log,只需调用:

 

[HAMLogOutputWindow clear];

 

源码解释

 

HAMLog

 

用来存储 log 信息的 model 类。有两个属性,时间戳和具体的 log 内容。

 

HAMLogOutputWindow

 

是一个单例的 Window,里面有一个 UITextView 用来显示 log。windowLevel 设为 UIWindowLevelAlert 所以能保持在最前。userInteractionEnabled 设为 NO,这样屏幕触摸事件会传递到下层的实际 view 上去,不会挡住测试的操作。

 

打印 log 的时候,建立一条 log 对象存进 logs 数组里。logs 数组实际是个队列,超出 20 条之后就会抛弃最旧的一条。之后调用 refreshLogDisplay 刷新 log 的显示。

 

在 refreshLogDisplay 这个方法中,首先根据 logs 数组构造一个 attributedString。其中时间戳与当前时间相差 0.1s 以内的,显示为黄色,否则显示为白色。这样就能在视觉上把前后关联比较紧密的 log 同时高亮,比如点击 tab 和相应 viewController 的 viewWillAppear 两个统计事件。

 

最后用以下代码让显示 log 的 UITextView 滚动到底部。

 

NSRange bottom = NSMakeRange(attributedString.length - 1, 1);

[self.textView scrollRangeToVisible:bottom];

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值