做一个帮你快速调试UI参数的Idea插件

本文会介绍一个帮助我们快速调试UI参数的插件开发过程以及开发思路,可能需要一些简单的Idea平台插件开发经验,希望对大家会有一些帮助。

插件介绍

插件基于Layout Inspector,强化了这个工具,故取名Layout Master

使用方式同Layout Inspector,呼出Android Studio(3.1以上)或Idea(2017.3以上)的Action面板,输入Layout Master点击即可,双击Property,支持修改的话会弹出Popup,同Layout Inspector一样,每次Activity重启了就需要再次运行Layout Master才可。

image

插件效果如下(图中仅演示了部分属性修改效果,支持很多属性)
LayoutMaster

项目Github地址:https://github.com/wuapnjie/LayoutMaster

为什么要做这个插件

我在平时的Android开发过程中,会经常修改一些UI的参数,比如padding,margin,color等等,有时View是通过非XML代码动态注入的,很多参数设置在真机调试时才能看到(而且我是那种一定要看真机跑效果的人),所以很多时候效果不满意就要改参数继续看效果,设计师们也会经常让我们改一些UI上的参数,这样每次都要重新编译运行一次代码,或者Instant Run一下,项目小还好,项目一大,这个重新编译运行的时间成本就会很大,大大降低了开发效率。于是我决定开发这个插件,快速看到UI参数改变的效果。

插件的简单原理介绍

不同于React Native和Flutter这些框架实现的热加载(哈哈,其实我也不知道这些框架怎么实现的),这个插件对View的参数实时设置都是通过Java反射调用View自身的setXXX()方法实现的,所以只能看效果,代码本质上没有改变,需要达到满意效果后再去修改,但这还是大大节省了时间,至少对我来说是。

那要怎么样做到从电脑端(IDE端)调用APP上View的setXXX()方法呢?很简单,让手机与电脑之间进行一个Socket长连接,定义一些命令协议,就可以实现电脑端对手机端的控制。

实现思路与过程

最初的思考

首先要实现想要的功能,第一步就是建立手机端与电脑端的Socket长连接并拿到关于Activity的View Hierarchy和View的Properties。这样的功能我在两个地方看到过,一个是Facebook强大的调试框架Stetho,另外一个就是Android Studio自带的Layout Inspector。这两个工具都与手机端建立了一个Socket长连接,建立了自己的通信协议。下面我会简单介绍一下两者的区别,并解释了为什么我选择基于Layout Inspector做一个插件,而不是基于Stetho做一个代码扩展。

Stetho

image

Stetho这个项目功能十分强大,不光可以看到View Hierarchy,还可以调试数据库,监测网络等等,实现上和我之前介绍的一样,建立了一个Socket长连接,APP负责获取需要的数据,通过Socket传输到Chrome DevTools,这里Chrome DevTools有一个开发API,接收到特定的Json,会进行渲染显示,在DevTools的操作也会Json格式包装成特定的数据包发送给APP进行操作。由于Stetho的代码比较复杂,我没有对其深入研究,也不了解Chrome DevTools的API,但大致原理已经介绍了,如果你感兴趣或有什么想法,可以去研究研究。

Layout Inspector

image

同样,Layout Inspector也是通过Socket长连接来获取APP的相关UI信息,由于Idea的社区版代码是开源的,而作为Android插件的Layout Inspector代码也是开源,具体可以编译Idea项目查看,代码入口在android插件AndroidRunLayoutInspectorAction.java类中。

两者差别

Stetho的Socket连接相关代码是写在它的库中的,需要调试的APP依赖这个项目,进行一些配置,侵入性较强,但功能强大。而Layout Inspector则对代码零侵入࿰

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SwissArmyKnife是什么SwissArmyKnife 是一款方便调试android UI的工具,可以兼容所有android版本,不需要root权限。可以直接在android手机屏幕上显示当前Activity中所有控件(不管是否隐藏)的边界,内外边距大小,每一个控件大小,图片大小,字体颜色,大小,以及自定义信息。同时可以直接在屏幕上取色,另外还提供了直尺(单位为px和dp),圆角尺(单位dp)工具,可以直接测量大小。针对android开发者还提供了布局树查看功能,可以直接在手机屏幕查看当前Activity中所有控件层次信息等。可以通过滚动层级滚轮来控制只显示某一层级的信息,避免层级覆盖等。使用方式compile 'com.wanjian:sak:0.0.3'android 4.0及以上用户直接在application的onCreate中调用 com.wanjian.sak.LayoutManager.init(Application context) ,其他版本可以在activity的onResume中调用com.wanjian.sak.LayoutManager.init(Activity act)初始化。启动app后会在屏幕左上角看到一个 android logo ,点击即可进入功能界面。功能界面边框选项开启边框选项后可以在手机屏幕看到所有控件的边界,效果如下内外边距选项开启后会在屏幕看到如下效果半透明绿色代表内边距,PT表示上边内边距(padding top),PL表示左内边距(padding left),PT表示右内边距(padding right),PB便是下内边距(padding bottom)。半透明红色代表外边距, ML,MT,MR,MB分别表示左外边距,上外边距,右外边距,下外边距。所有边距单位都是dp(pt),android中会四舍五入,所有边距都是整数,所以可能跟设计图中有不超过1dp(pt)的误差。宽高选项开启后会看到控件的宽高,单位是dp(pt)图片宽高字体大小字体颜色16进制,ARGB强制图片宽高若开启图片宽高选项后看不到图片大小,可以尝试开启强制图片宽高选项。 ps 该选项可能会导致滑动卡顿自定义信息自定义信息用于android开发者调试使用,开发者可以为view设置setTag(com.wanjian.sak.CanvasManager.INFO_KEY,Object),设置后并开启自定义信息选项后就可以在控件左上角看到自定义的文本信息了。比如开发者想要在屏幕上看到TextView中有多少个文字,就可以这样使用textview.setTag(com.wanjian.sak.CanvasManager.INFO_KEY,textview.getText().length()),这样开启自定义信息选项后就可以在TextView上看到文字长度了。实时刷新开启实时刷新后当手指在屏幕上移动时就可以实时看到相关信息,开启实时刷新后可能会导致滑动卡顿,也可能导致触摸,点击等失效。层级信息可以通过滚动滚轮来控制只显示某一层次区间的信息,比如只想看ListView中子控件的大小,就可以滚动滚轮来控制只显示ListView子控件大小,具体调整成多少需要多次尝试。滚轮可以控件边框,宽高,布局树等等。直尺圆角尺,取色器开启后会在屏幕左上角显示,取色器刚开启时只会在屏幕左上角看到一个黑框,拖动到要取色的位置后抬起手机即可完成取色,取色器四个角可以获取所指像素的颜色值。取色器可以获取native页面每个像素颜色,也可以获取webview中每一个像素的颜色。布局树布局树可以双指缩放扩展用户可以方便的对SAK进行扩展,只需要继承自AbsCanvas并重新onDraw(Canvas canvas, Paint paint, ViewGroup viewGroup, int startLayer, int endLayer),或者继承自CanvasLayerAdapter并重写drawLayer(Canvas canvas, Paint paint, View view)又或者继承自CanvasLayerTxtAdapter区别在于onDraw中没对层级进行处理,drawLayer中的view已经是层级区间的view,CanvasLayerTxtAdapter提供了drawTxt(String txt, Canvas canvas, Paint paint, View view)方法,可以直接调用drawTxt就可以把txt绘制到当前view左上角。写完自定义的Canvas后还需要在OperatorView布局中加入布局代码,用于开启自定义的Canvas,比如在布局中加入开关按钮,并为按钮添加监听,开启后调用 Canvas
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值