Android Studio插件开发之 - 基础入门篇

红橙Darren
• 阅读 2016

1.概述


上一期我们已经自己动手打造了一套IOC注解框架。如何才能像ButterKnife一样自动给我们生成代码呢?所以我们不得不去了解Android Studio的插件开发了。

我们在开发的过程中对Android Studio的插件应该并不陌生,我们也时常用到比如:
  GsonFormat:现在大多数服务端api都以json数据格式返回,而客户端需要根据api接口生成相应的实体类,这个插件把这个过程自动化了。
  LeakCanary:强烈推荐,帮助你在开发阶段方便的检测出内存泄露的问题,使用起来更简单方便。

大家可以自己上网去了解很多很多好用的插件,但是在我们的实际开发过程中我们肯定碰到过这种情况。项目的很多类里面某些代码我们可能在版本迭代的时候需要修改,而修改的内容基本一致,这个时候是不是可以写一个插件自动修改代码。举一个最简单的例子,拿Log打印日志来说我们在上线的时候肯定要关闭Log打印是不是可以写一个插件把所有Log打印注释掉,当然在实际的开发过程中会有Log开关。
  上一期我们是因为觉得ButterKnife插件生成的代码怪怪的,又不能动态的检测网络所以自己才会动手打造一套IOC注解框架,既然是自己挖的坑说什么也要填上,那么这一期我们就自己来写一个Android Studio的IOC注解生成插件配套我们上一期的IOC注解框架。

所有分享大纲:2017Android进阶之路与你同行

视频讲解地址:http://pan.baidu.com/s/1gf40cV5

2.你好世界


网上资料太多都是你好世界,找了很久也没有视频教程,估计很少有人自己写大部分肯定都是用的别人的。基于这个我们还是老老实实先来HelloWorld吧。
  android studio的插件开发必须用IntelliJ IDEA,不能直接在android studio中直接开发,所以首先下载IntelliJ IDEA,(官网下载,直接下载社区版本就好。下载安装就不讲解了,一路下一步就ok。同样,IntellJ IDEA 运行在java上,还需要在java sdk。当然你也可以在视频讲解的云盘里面下载IntelliJ IDEA。

2.1 初次运行

启动 IntelliJ IDEA,首次启动后出现如下界面,因为是新装的IntelliJ IDEA,直接选择最后一个,点击Ok。我还是贴个图吧:

Android Studio插件开发之 - 基础入门篇

选择界面风格,这个随意了,我选择白色,因为要视频讲解. 然后点击Next:Default plugins。

Android Studio插件开发之 - 基础入门篇

428839-42e59c45a957336a.png

点击 Next:Featured plugins。

Android Studio插件开发之 - 基础入门篇

点击 Start using IntelliJ IDEA

Android Studio插件开发之 - 基础入门篇

点击Create New Project,进入你好我也好世界

Android Studio插件开发之 - 基础入门篇

2.2 初建项目

选择IntelliJ Platform Plugin,然后点击右边的New...按钮,这个是要配置IntelliJ 的SDK

Android Studio插件开发之 - 基础入门篇

  
点击New后,会弹出对话框,选择OK,以后再新建项目就不要再干这事了要不然提示你会蒙B

Android Studio插件开发之 - 基础入门篇

在弹出的目录选择框中一般会自动选择到你的jdk目录,如果不是,请自己选择jdk目录,建议jdk版本用1.8以上的。

Android Studio插件开发之 - 基础入门篇

上一步ok以后会弹出选择IntelliJ Platform Plun SDK的对话框,一般也会自动选择对,ok就好

Android Studio插件开发之 - 基础入门篇

接着弹出Java SDK版本选择,选择1.8

Android Studio插件开发之 - 基础入门篇

返回到项目创建窗口,下一步,创建HelloWorld

Android Studio插件开发之 - 基础入门篇

  
点击颜色不一样的那个按钮,如果很快可以看到下面这个页面说明你电脑很不错,如果要等半天恭喜你该换电脑了,如果实在慢就耐心等一等。

Android Studio插件开发之 - 基础入门篇

3.初次扫盲


下面我们就逐个进行介绍,一进来自动就会打开plugin.xml这个文件我们就从这个开始。
  
  3.1 plugin.xml

  • id:插件的ID,保证插件的唯一性,如果上传仓库的话。
  • name:插件名称。
  • version:版本号。
  • description:插件的简介。
  • change-notes:版本更新信息。
  • extensions:扩展组件注册 。
  • actions:Action注册,比如在某个菜单下增加一个按钮就要在这注册,刚刚建的项目目前肯定看不到Action.

3.1 新建Action
  
  其他目录就没什么好解释的了,可以自己大概去浏览一下,plugin.xml其实也就是配置一些信息而已,下面这个就比较重要了,我们的插件代码都是在src中有一种体现形式就是Action。那么我们来新建Action,在src上单击右键 弹出菜单选择New ---Action,创建一个动作。

Android Studio插件开发之 - 基础入门篇

弹出New Action配置窗口,进行配置

Android Studio插件开发之 - 基础入门篇

  • ActionID:代表该Action的唯一的ID
  • ClassName:类名
  • Name:插件在菜单上的名称
  • Description:对这个Action的描述信息
  • Groups:定义这个菜单选项出现的位置我们选择的是Code菜单,右边的Anchor是选择该选项出现的位置,默认First即最顶部。
  • Keyboard Shortcts:快键键,按住几个组合键它自动会填好

点击OK,可以看到在plugin.xml的 action节,多了刚才选择和配置的内容,同时打开一个叫.java的文件,就是我们动作的主文件,我们暂时在文件中添加一个消息框显示代码(你好世界)

public class HelloWorld extends AnAction {

    @Override
    public void actionPerformed(AnActionEvent e) {
        // 获取选中内容
        final Editor mEditor = e.getData(PlatformDataKeys.EDITOR);
        showPopupBalloon(mEditor, "你好世界", 5);
    }


    /**
     * 显示dialog
     *
     * @param editor
     * @param result 内容
     * @param time   显示时间,单位秒
     */
    public static void showPopupBalloon(final Editor editor, final String result, final int time) {
        ApplicationManager.getApplication().invokeLater(new Runnable() {
            public void run() {
                JBPopupFactory factory = JBPopupFactory.getInstance();
                factory.createHtmlTextBalloonBuilder(result, null, new JBColor(new Color(116, 214, 238), new Color(76, 112, 117)), null)
                        .setFadeoutTime(time * 1000)
                        .createBalloon()
                        .show(factory.guessBestPopupLocation(editor), Balloon.Position.below);
            }
        });
    }
} 

现在千万别纠结代码,肯定蒙B因为很多人估计看不懂,现在只需要知道他是弹出一个你好世界的框框就行。接下来我们可以点击右上角的绿色三角run起来,大致的效果就是会重新启动IDE在code菜单里面会出现一个选项,点击会弹出一个你好世界的框框。我这里就直接生成插件算了,因为最终是要运行到Android Studio里面。

3.2 生成插件Plugin
  
  点击Build选择 Prepare Plugin Moudule....打包成jar

Android Studio插件开发之 - 基础入门篇

打包完成后,会在项目结构中看见这个HelloWorld.jar文件。至此打包完毕,注意生成jar的目录就好,下一步在android studio中安装这个插件

Android Studio插件开发之 - 基础入门篇

3.2 安装插件
  安装插件其实没什么好讲的了,但是大家平时安装都是在线的插件,只不过这一次安装的是本地插件而已。把生成的jar包插件复制出来放到桌面,然后选择本地插件安装:

Android Studio插件开发之 - 基础入门篇

  
  安装后重启Android Studio,可以选择Code菜单也可以直接按我们设置的快捷键都行,我的快捷键冲突了按不了,如果快捷键冲突了回过头再去改一下。

Android Studio插件开发之 - 基础入门篇

GIF.gif

所有分享大纲:2017Android进阶之路与你同行

视频讲解地址:http://pan.baidu.com/s/1gf40cV5

下一期我们会讲解Android Studio 插件开发实战篇,像butterKnife的插件一样配套我们自己IOC注解框架

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Android So动态加载 优雅实现与原理分析
背景:漫品Android客户端集成适配转换功能(基于目标识别(So库35M)和人脸识别库(5M)),导致apk体积50M左右,为优化客户端体验,决定实现So文件动态加载.!(https://oscimg.oschina.net/oscnet/00d1ff90e4b34869664fef59e3ec3fdd20b.png)点击上方“蓝字”关注我
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Eclipse插件开发_学习_00_资源帖
一、官方资料 1.eclipseapi(https://www.oschina.net/action/GoToLink?urlhttp%3A%2F%2Fhelp.eclipse.org%2Fmars%2Findex.jsp%3Ftopic%3D%252Forg.eclipse.platform.doc.isv%252Fguide%2
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
9个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这