Android Studio的Model代码插件开发
为什么80%的码农都做不了架构师?>>>
源码地址
背景
码工们做的很多工作,很多时候是为了减少这个世界上的重复工作。在为这个世界带来便捷的时候,当然也要不忘给自己的工作减负,提高工作的效率啦。在对接API的时候,我们要根据出来的字段定义相关的数据模型,在复制粘贴几次之后,我开始厌倦这种没有半点技术含量的重复性工作,所以开始思考怎么把这个工作自动化,砍柴不误磨刀工,我相信额外的一点付出会带来效率的提升。
当前我们开发用的IDE是Android Studio, 大家都只都这个是基于intellij开发的,所以能集成在intellij里面就最好了。
目前我们的api文档有两种格式(规范不好的原因),一种是表格,字段名和类型信息都有了,如下:
字段 | 类型 | 描述 |
---|---|---|
pkgFile | String | 包链接 |
gameId | long | 游戏id |
channelName | String | 渠道名 |
另外一种就是偷懒的写法,直接把返回的Json贴上去:
{"id": 1,"gameName": "这是游戏标题","gameRecommendText": "游戏一句话推荐","cover": "封面图片","ugcTime": "一天前","gameIcon": "这是游戏图标","gameDownloadUrl": "这是游戏下载链接","ugcTitle": "这是资讯标题","style": 1,"ugcViewCount": 333,"ugcSource": "咨询来源","videoLength": "12'33''"
}
这里当然两种格式都要很好的支持啦,笔者发现表格直接在网页上复制,然后粘贴到文本输入框中的格式是非常整齐的空格隔开的,格式如下:
pkgFile String 包链接
gameId long 游戏id
channelName String 渠道名
因此我们的数据源就很好确定了,而且也很方便。根据这两种数据源,我们约定:
- 基本类型比如
int
,long
和对应的类类型Integer
则返回基本类型。 - 没有类型信息或者其他类型用String类型。
下面我们就开始开始这个插件的开发探索吧,笔者希望能抛砖引玉,大家能在平时的工作中有意识根据自己的需要做出更多好用的工具,优化开发流程和开发效率。
intellij插件开发基础知识
开发准备
这里我建议大家看官方的文档,已经介绍很详细了,我在下面也会简单介绍,传送门
- 下载安装intellij社区版: 下载地址
- 配置IntelliJ Platform Plugin SDK。
- 创建一个Plugin Project。
- 运行和调试
- 发布插件,这里我建议大家配置Ant来构建,我发现在引入libs包的时候生成的插件主工程会少很多文件,导致无法正常运行,用Ant打包就正常了。
懒人版:
- 配置Intellij SDK: 打开Project Structure对话框[
Ctrl+Shift+Alt+S
],选择Intellij的目录:
2. 新建Plugin Project:
3. 新建完成工程目录结构:
其中plugin.xml文件就是我们注册AnAction
的地方。
AnAction介绍
AnAction就是IDE相关位置的事件触发处理的地方,要创建一个Action,只需要简单的两个步骤:
- 定义一个
AnAction
,你通常需要继承AnAction
类,然后在actionPerformed
方法里面实现你的操作。 - 在plugin.xml里面注册这个
AnAction
。
intellij社区版里面创建Action非常方便,你可以通过图像界面很容易找到自己想要放置的Action位置,比如我们要在Code
菜单下的Generate..
下面放置我们的Action,那么只需要在Groups
中找到相应的位置即可:
- Action ID: 每个Action都需要一个唯一的ID.
- Class Name: Action的类名,我们是在
ithub.yedaxia.plugin.actions
下面建的。 - Name: 名字,就是在界面上我们看到的名字。
- Description: 描述信息,鼠标放在上面一小段时间可以看到的描述信息。
- Groups: 可以理解为Action集合。
- Keyboard Shortcuts: 快捷键设置,这里我们暂时不需要了。
生成之后我们可以看到在plugin.xml
里面就有对应的Action了:
<action id="CodeGenerationPlugin.EntryAction" class="github.yedaxia.plugin.actions.EntryAction"text="EntryGenerator..." description="Entry Code Generator"><add-to-group group-id="CodeMenu" anchor="after" relative-to-action="Generate"/>
</action>
对应的AnAction代码:
public class EntryAction extends AnAction {@Overridepublic void actionPerformed(AnActionEvent e) {//点击EntryGenerator...按钮之后调用这个方法}
}
代码生成界面:
代码生成的逻辑并不复杂,我们把这个放到最后,本文还是着重介绍intellij插件的编写,现在我们已经有了程序的入口了,我们还需要一些简单的UI元素,一个对话框,一个简单的输入框[类名],比较大的文本框[数据源和生成的最终代码]。
先看最后的效果:
intellij本身运行在Java上面,所以java swing库支持肯定是没问题的,这个对话框我主要参考了android-codegenerator-plugin-intellij里面的实现。
里面用到了com.intellij.openapi.ui.DialogBuilder
,相关api文档没有找到,通过源码也不难发现其用法:
setTitle
: 标题setCenterPanel(JComponent centerPanel)
: 对话框中间面板,JComponent对于Java程序员应该就不陌生了。addAction
: 添加底部的按钮和相关事件。
具体的代码可以看: CodeDialogBuilder.java
生成代码
代码生成主要包括两个步骤:
- 代码模板设计。
- 代码构建。
模板的设计也是参考了android-codegenerator-plugin-intellij项目,根据Model数据模板的特点,我分成了以下四个代码模板:
- Entry_template: 目标代码模板。
- Entry_Field_template: 类字段模板。
- Entry_Setter_template: setter方法模板。
- Entry_Setter_template: getter方法模板。
Json解析我用的是alibaba的fastjson,所以模板就是长下面的样子了,大家可以根据自己的需要去修改:
Entry:
public class ${CLASS_NAME} implements Serializable{${FIELDS}
${METHODS}
}Field:
private ${FIELD_TYPE} ${FIELD_NAME};Getter:
@JSONField(name="${REMOTE_FIELD_NAME}")
public ${FIELD_TYPE} get${CASE_FIELD_NAME}(){return ${FIELD_NAME};
}Setter:
@JSONField(name="${REMOTE_FIELD_NAME}")
public void set${CASE_FIELD_NAME}(${FIELD_TYPE} ${FIELD_NAME}){this.${FIELD_NAME} = ${FIELD_NAME};
}
具体的代码构建过程这里就不详细讲了,大家可以移步github,这个过程应该不难理解。如果觉得这个插件有用,你可以给个star。
思考
这个工具的开发过程比我想象中要简单很多,一天时间左右应该就差不多完成的了,后续带来的好处和省下来的时间肯定会弥补回这个时间代价,有些码工经常会觉得麻烦或者根本没有这个意识,宁愿麻烦一些也不愿意去写个工具来加速自己的工作,我觉得是不可取的,我们应该用重构和工具去避免写重复的代码,把更多的时间放到有价值和有创造性的工作上面来,从中长期来看,这样带来的好处是巨大的,更快的开发速度、鲁棒性更好的系统等,更重要的是个人也获得了成长。
参考资料
- IntelliJ Plugin Development Guidelines
- android-codegenerator-plugin-intellij
- Intellij 生成Ant工程
- IntelliJ Plugin Development Docs
转载于:https://my.oschina.net/daxia/blog/811619
Android Studio的Model代码插件开发相关推荐
- Android Studio中的代码格式快捷方式
本文翻译自:Code formatting shortcut in Android Studio I have started developing with Android Studio . 我已经 ...
- 【错误记录】Android Studio 的 Flutter 代码界面没有 Logcat 面板 ( 2021年08月28日最新解决方案 )
文章目录 前言 一. 报错信息 二. 解决方案 前言 在之前的博客 [错误记录]Android Studio 的 Flutter 代码界面没有 Logcat 面板 中 , 处理了该问题 , 不过时去年 ...
- Android Studio快捷键之代码提示
相信很多人在用Eclipse的时候,很习惯的都会把Content Assist设置成.abcd...z,这样每次敲代码的时候都会有自动提示,写起代码来很方便.具体设置如图: 同时,Eclipse中也有 ...
- Android Studio 上传代码到Gitee
最近在学校里做Android的项目,一直不会通过Android Studio上传代码到Gitee,经过查阅博客和文章,现在将方法总结如下: 一.安装Git 1.下载Git 可在Git官网下载 http ...
- android studio统计方法数,android studio如何统计代码行数
1.首先打开Android Studio开发工具. 2.FileSettings选项或者单击快捷菜单里的settings设置图标. 3.弹出settings对话框,搜索框输入 line 敲回车搜索. ...
- android如何设置自动补,Android Studio 中设置代码块自动补齐
AS中很多提示键,并不如Eclipse中做的好,需要我们自己去自定义.这里以switch...case为例,讲解一下如何设置代码自动补全. 1.进入settings --> Editor -- ...
- 在Android Studio中进行代码混淆
此文章来源于http://blog.csdn.net/wenwen091100304/article/details/52802247点击打开链接 在Android APP开发完成后,为了防止APP被 ...
- Android Studio——怎么设置代码补全以及提示(详细)?
文章目录 一.代码提示设置 二.代码自动补全快捷键 如果你喜欢Eclipse 或者MyEclipse的快捷键提示代码 "Alt+/" 那么请往下看 一.代码提示设置 1.左上角点击 ...
- Android Studio中有没有类似于Eclipse中的ctrl+2+L的快捷键? \Android Studio快捷键之代码提示...
问:Android Studio中有没有类似于Eclipse中的ctrl+2+L的快捷键? 答:有,as中的快捷键是Ctrl+Alt+V AndroidStudio和Eclipse常用快捷键对比 功能 ...
最新文章
- springboot2处理跨域
- linux 脚本select菜单,Shell:如何写一个多选菜单的脚本
- Ubuntu 里的Spyder不能切换中文输入
- sqlserver 跨服务器备份表
- 【随机过程】随机过程之泊松过程的推广
- oracle sql 语句 start with ...... connect by prior .......
- void init(void) 分析 ! \linux-1.0\init\main.c
- mysql表的relationship_sqlalchemy 配置多连接读写库后的relationship设置
- Adobe Reader 9.0记住阅读位置
- 远程运维方案选型指南:官网可下载的ZStack私有云平台 | 凌云时刻
- R语言中写入Excel的不同sheet表格
- ztree 后台异步加载_Ztree 分批异步加载
- Multisim14.0安装教程
- 第74句Lies, Damned Lies And Statistics: How Bad Statistics Are Feeding Fake News
- 12 经络的走向图和说明
- JavaScript最详细基础语法总结(跳坑记录!)
- Catch the moments of your life. Catch them while you're young and quick.
- Redis-14Redis超时命令
- 通过刷DD-WRT固件的路由器访问猫
- 消费者权益法规的精神