文档章节

Android Studio的Model代码插件开发

叶大侠
 叶大侠
发布于 2016/12/25 17:01
字数 1881
阅读 99
收藏 0

源码地址

背景

码工们做的很多工作,很多时候是为了减少这个世界上的重复工作。在为这个世界带来便捷的时候,当然也要不忘给自己的工作减负,提高工作的效率啦。在对接API的时候,我们要根据出来的字段定义相关的数据模型,在复制粘贴几次之后,我开始厌倦这种没有半点技术含量的重复性工作,所以开始思考怎么把这个工作自动化,砍柴不误磨刀工,我相信额外的一点付出会带来效率的提升。

当前我们开发用的IDE是Android Studio, 大家都只都这个是基于intellij开发的,所以能集成在intellij里面就最好了。

目前我们的api文档有两种格式(规范不好的原因),一种是表格,字段名和类型信息都有了,如下:

字段类型描述
pkgFileString包链接
gameIdlong游戏id
channelNameString渠道名

另外一种就是偷懒的写法,直接把返回的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插件开发基础知识

开发准备

这里我建议大家看官方的文档,已经介绍很详细了,我在下面也会简单介绍,传送门

  1. 下载安装intellij社区版: 下载地址
  2. 配置IntelliJ Platform Plugin SDK
  3. 创建一个Plugin Project
  4. 运行和调试
  5. 发布插件,这里我建议大家配置Ant来构建,我发现在引入libs包的时候生成的插件主工程会少很多文件,导致无法正常运行,用Ant打包就正常了。

懒人版:

  1. 配置Intellij SDK: 打开Project Structure对话框[Ctrl+Shift+Alt+S],选择Intellij的目录:

2. 新建Plugin Project:

3. 新建完成工程目录结构:

其中plugin.xml文件就是我们注册AnAction的地方。

AnAction介绍

AnAction就是IDE相关位置的事件触发处理的地方,要创建一个Action,只需要简单的两个步骤:

  1. 定义一个AnAction,你通常需要继承AnAction类,然后在actionPerformed方法里面实现你的操作。
  2. 在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 {
    @Override
    public 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

生成代码

代码生成主要包括两个步骤:

  1. 代码模板设计。
  2. 代码构建。

模板的设计也是参考了android-codegenerator-plugin-intellij项目,根据Model数据模板的特点,我分成了以下四个代码模板:

  1. Entry_template: 目标代码模板。
  2. Entry_Field_template: 类字段模板。
  3. Entry_Setter_template: setter方法模板。
  4. 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。

思考

这个工具的开发过程比我想象中要简单很多,一天时间左右应该就差不多完成的了,后续带来的好处和省下来的时间肯定会弥补回这个时间代价,有些码工经常会觉得麻烦或者根本没有这个意识,宁愿麻烦一些也不愿意去写个工具来加速自己的工作,我觉得是不可取的,我们应该用重构和工具去避免写重复的代码,把更多的时间放到有价值和有创造性的工作上面来,从中长期来看,这样带来的好处是巨大的,更快的开发速度、鲁棒性更好的系统等,更重要的是个人也获得了成长。

参考资料

  1. IntelliJ Plugin Development Guidelines
  2. android-codegenerator-plugin-intellij
  3. Intellij 生成Ant工程
  4. IntelliJ Plugin Development Docs

© 著作权归作者所有

共有 人打赏支持
叶大侠

叶大侠

粉丝 58
博文 44
码字总数 67312
作品 5
广州
程序员
私信 提问
ButterKnife注解框架详解

  Android 懒人注解框架 :https://github.com/JakeWharton/butterknife   前言:     注解,相信很多同学都用到了,对控件进行初始化的时候需要用到 findViewById() ,当一个activit...

听着music睡
2017/04/12
0
0
Android Studio简单设置

界面设置 默认的 Android Studio 为灰色界面,可以选择使用炫酷的黑色界面。 Settings --> Appearance --> Theme ,选择 Darcula 主题即可。 字体设置 系统字体设置 如果你的Android Studio界...

会飞柚子
2015/11/21
0
0
Android Studio简单设置

Android Studio 简单设置 界面设置 默认的 Android Studio 为灰色界面,可以选择使用炫酷的黑色界面。 Settings --> Appearance --> Theme ,选择 Darcula 主题即可。 字体设置 系统字体设置...

Erichkko
2015/11/21
0
0
Android studio常用设置详解

1.1 界面设置 默认的 Android Studio 为灰色界面,可以选择使用炫酷的黑色界面。 Settings --> Appearance --> Theme ,选择 Darcula 主题即可。 1.2 字体设置 如果你的Android Studio界面中...

dailei1021
2015/11/05
0
0
给 Android 开发者的 Gradle 入门指南

本文的目的是为您提供关于 Gradle 的高级概述,以及在开发 Android 应用程序时如何适应整个构建系统。 我将通过 Gradle 和 Gradle 的 Android 插件的基础知识,以及新的 Android 项目附带的默...

oschina
2017/11/22
3K
2

没有更多内容

加载失败,请刷新页面

加载更多

大数据教程(9.5)用MR实现sql中的jion逻辑

上一篇博客讲解了使用jar -jar的方式来运行提交MR程序,以及通过修改YarnRunner的源码来实现MR的windows开发环境提交到集群的方式。本篇博主将分享sql中常见的join操作。 一、需求 订单数据表...

em_aaron
12分钟前
0
0
十万个为什么之什么是resultful规范

起源 越来越多的人开始意识到,网站即软件,而且是一种新型的软件。这种"互联网软件"采用客户端/服务器模式,建立在分布式体系上,通过互联网通信,具有高延时(high latency)、高并发等特点...

尾生
18分钟前
0
0
《告诉你真实的美国教育》的读后感3900字

《告诉你真实的美国教育》的读后感3900字: 文章的开篇分析了我们耳熟能详的关于美国教育的小故事,就是那个因为幼儿园的老师教了“0”这个字母,然后妈妈告老师剥夺了孩子的想象力,再然后幼...

原创小博客
26分钟前
0
0
Terraform配置文件(Terraform configuration)

Terraform配置文件 翻译自Terraform Configuration Terraform用文本文件来描述设备、设置变量。这些文件被称为Terraform配置文件,以.tf结尾。这一部分将讲述Terraform配置文件的加载与格式。...

buddie
41分钟前
2
0
exportfs命令, vsftp搭建ftp服务

exportfs命令 当修改/etc/exports文件后,更改的内容是不会立即生效的。如果重启nfs服务,会导致客户端重启期间的请求是挂起等待的,可以把客户端的挂载umount进行卸载后,再重启nfs服务,但...

野雪球
52分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部