android filehelper,为AndroidStudio开发mvp插件(MvpHelper)

如果觉得写mvp有点枯燥无味,我们可以做点 cool 的事情:做个 as 插件

47509e1684a1

help.png

todo-mvp: 基础的MVP架构。

todo-mvp-loaders:基于MVP架构的实现,在获取数据的部分采用了loaders架构。

todo-mvp-databinding: 基于MVP架构的实现,采用了数据绑定组件。

todo-mvp-clean: 基于MVP架构的clean架构的实现。

todo-mvp-dagger2: 基于MVP架构,采用了依赖注入dagger2。

dev-todo-mvp-contentproviders: 基于mvp-loaders架构,使用了ContenPproviders。

dev-todo-mvp-rxjava: 基于MVP架构,对于程序的并发处理和数据层(MVP中的Model)的抽象。

因为对mvp的理解不同,会有很多种方式表达架构,所以插件要极简易读,可扩展性强,所以可以选择:

/**

* 通过模板生成类

* @param var1 文件生成路径

* @param var2 文件名

* @param var3 模板名

* @param var4 是否生产类

* @param var5 模板参数

*/

public abstract PsiClass createClass(@NotNull PsiDirectory var1, @NotNull String var2, @NotNull String var3, boolean var4, @NotNull Map var5) throws IncorrectOperationException;

也就是只要定制不同的模板就可以实现扩展性

直接贴下步骤:

1: idea File - new - Project - IntelliJ Platform Plugin

47509e1684a1

dir.PNG

plugin.xml 插件配置信息:

com.your.company.unique.plugin.id

Plugin display name here

1.0

YourCompany

Enter short description for your plugin here.

most HTML tags may be used

]]>

Add change notes here.

most HTML tags may be used

]]>

description="Generate MVP" icon="/icons/app_icon.png">

action:

public class MvpGenerator extends AnAction implements MvpHandler.OnGenerateListener {

private AnActionEvent actionEvent;

private MvpHandler mvpHandler;

private Map map = new HashMap<>();

@Override

public void actionPerformed(AnActionEvent anActionEvent) {

this.actionEvent = anActionEvent;

mvpHandler = new MvpHandler();

mvpHandler.setTitle("输入名称-生成MVP相关类");

mvpHandler.setOnGenerateListener(this);

mvpHandler.pack();

//设置对话框跟随当前windows窗口

mvpHandler.setLocationRelativeTo(WindowManager.getInstance().getFrame(anActionEvent.getProject()));

mvpHandler.setVisible(true);

}

@Override

public void onGenerate(String text) {

JavaDirectoryService directoryService = JavaDirectoryService.getInstance();

//当前工程

Project project = actionEvent.getProject();

map.put("NAME", text);

map.put("PACKAGE_NAME", Util.getPackageName(project));

//鼠标右键所选择的路径

IdeView ideView = actionEvent.getRequiredData(LangDataKeys.IDE_VIEW);

PsiDirectory directory = ideView.getOrChooseDirectory();

assert directory != null;

if (directory.getName().contains("contract") && directory.findFile(text + "Contract.java") == null) {

directoryService.createClass(directory, text + "Contract", "GenerateContractFile", true, map);

}

if (directory.getName().contains("model") && directory.findFile(text + "Model.java") == null) {

directoryService.createClass(directory, text + "Model", "GenerateModelFile", true, map);

}

if (directory.getName().contains("presenter") && directory.findFile(text + "Presenter.java") == null) {

directoryService.createClass(directory, text + "Presenter", "GeneratePresenterFile", true, map);

}

}

@Override

public void onCancel() {

mvpHandler.setVisible(false);

}

}

dialog: (action下,右键,new dialog)

public class MvpHandler extends JDialog {

private JPanel contentPane;

private JButton buttonOK;

private JButton buttonCancel;

private JTextArea textArea1;

private OnGenerateListener listener;

public void setOnGenerateListener(OnGenerateListener listener) {

this.listener = listener;

}

public MvpHandler() {

setContentPane(contentPane);

setModal(true);

getRootPane().setDefaultButton(buttonOK);

buttonOK.addActionListener(e -> listener.onGenerate(textArea1.getText().trim()));

buttonCancel.addActionListener(e -> listener.onCancel());

// call onCancel() when cross is clicked

setDefaultCloseOperation(DO_NOTHING_ON_CLOSE);

addWindowListener(new WindowAdapter() {

public void windowClosing(WindowEvent e) {

listener.onCancel();

}

});

// call onCancel() on ESCAPE

contentPane.registerKeyboardAction(e -> listener.onCancel(), KeyStroke.getKeyStroke(KeyEvent.VK_ESCAPE, 0), JComponent.WHEN_ANCESTOR_OF_FOCUSED_COMPONENT);

}

public interface OnGenerateListener{

void onGenerate(String text);

void onCancel();

}

}

MvpHandler.form 拖动控件

47509e1684a1

dialog.PNG

Util:

public class Util {

/**

* AndroidManifest.xml 获取 app 包名

* @return

*/

public static String getPackageName(Project project) {

String package_name = "";

DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

try {

DocumentBuilder db = dbf.newDocumentBuilder();

Document doc = db.parse(project.getBasePath() + "/app/src/main/AndroidManifest.xml");

NodeList nodeList = doc.getElementsByTagName("manifest");

for (int i = 0; i < nodeList.getLength(); i++) {

Node node = nodeList.item(i);

Element element = (Element) node;

package_name = element.getAttribute("package");

}

} catch (Exception e) {

e.printStackTrace();

}

return package_name;

}

}

2: 定制模板:按需求定制

new - file - xxx.java.ft

GenerateContractFile.java.ft

#if (${PACKAGE_NAME} && ${PACKAGE_NAME} != "")

package ${PACKAGE_NAME};

#end

import base.IBaseModel;

import base.IBaseView;

import base.IPresenter;

public interface ${NAME}Contract{

interface I${NAME}View extends IBaseView{

}

interface I${NAME}Model extends IBaseModel{

}

interface I${NAME}Presenter extends IPresenter{

}

}

GenerateModelFile.java.ft

#if (${PACKAGE_NAME} && ${PACKAGE_NAME} != "")package ${PACKAGE_NAME};#end

import ${PACKAGE_NAME}.contract.${NAME}Contract;

import base.IBaseModel;

public class ${NAME}Model implements ${NAME}Contract.I${NAME}Model{

public static IBaseModel newInstance(){

return new ${NAME}Model();

}

}

GeneratePresenterFile.java.ft

#if (${PACKAGE_NAME} && ${PACKAGE_NAME} != "")

package ${PACKAGE_NAME}

;#end

import ${PACKAGE_NAME}.contract.${NAME}Contract;

import ${PACKAGE_NAME}.model.${NAME}Model;

import base.BasePresenter;

public class ${NAME}Presenter extends BasePresenter implements ${NAME}Contract.I${NAME}Presenter{

@Override

public ${NAME}Contract.I${NAME}Model bindModel(){

return (${NAME}Contract.I${NAME}Model)${NAME}Model.newInstance();

}

}

MVP:

BasePresenter:

public abstract class BasePresenter implements IPresenter {

protected T mView;

protected M mModel;

protected CompositeDisposable mDisposable;

public BasePresenter() {

this.mModel = bindModel();

mDisposable = new CompositeDisposable();

}

public boolean isViewAttached() {

return mView != null;

}

public void checkViewAttached() {

if (!isViewAttached()) throw new RuntimeException("未注册View");

}

@Override

public void onAttach(T t) {

mView = t;

if (mModel == null) {

throw new NullPointerException("model没有绑定 不能使用");

}

}

/**

* return Model

*/

public abstract M bindModel();

@Override

public void onDetach() {

if (!mDisposable.isDisposed())

mDisposable.dispose();

mView = null;

}

}

IBaseModel:

package base;

/**

* Created by haoran on 2018/4/4.

*/

public interface IBaseModel {

}

IBaseView :

package base;

/**

* Created by haoran on 2017/10/30.

*/

public interface IBaseView {

void showLoading();

void hideLoading();

void onError(String message);

}

IPresenter:

package base;

/**

* Created by haoran on 2017/10/30.

*/

public interface IPresenter {

void onAttach(T t);

void onDetach();

}

实现类:(引导页为例)... import 忽略

GuideContract:

public interface GuideContract {

interface IGuideView extends IBaseView{

void showGuideImages(List pictureListBeans);

void showGuideDefaultImage();

}

interface IGuideModel extends IBaseModel {

Observable> getGuideImages();

}

interface IGuidePresenter extends IPresenter {

void getGuideImages();

}

}

GuideModel:

public class GuideModel implements GuideContract.IGuideModel {

public static IBaseModel newInstance() {

return new GuideModel();

}

public Observable> getGuideImages() {

return ApiHelper.get().getGuideImages(new JSONObject());

}

}

GuidePresenter:

public class GuidePresenter extends BasePresenter implements GuideContract.IGuidePresenter {

@Override

public void getGuideImages() {

checkViewAttached();

mDisposable.add(mModel.getGuideImages().subscribe(pictureList -> {

if (pictureList == null || pictureList.size() == 0) {

mView.showGuideDefaultImage();

} else {

mView.showGuideImages(pictureList);

}

}, throwable -> mView.showGuideDefaultImage()));

}

@Override

public GuideContract.IGuideModel bindModel() {

return (GuideContract.IGuideModel) GuideModel.newInstance();

}

}

根据自己实际的mvp实现类定制模板

3: 打包插件,as引入插件,使用插件(插件开发调试忽略)

打包:idea里 build - Prapare Pulgine Module 'xxx' for Developer

项目目录下的jar包

打开as -- setting pulgine import from disk : jar 包目录

重启as

选中目录(含contract , model ,presenter) alt + i(快捷键可在plugine.xml配置)

或 右键 - new - 点击插件图标

输入 名称(XXX)--- 生成 java 类

47509e1684a1

generate1.PNG

点击ok

47509e1684a1

generate2.PNG

感谢:)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/508056.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android+5.q,MSM8909+Android5.1.1电池管理(2)--qpnp-linear-charger.txt驱动学习概要

MSM8909Android5.1.1电池管理(2)--qpnp-linear-charger.txt驱动学习概要参考文件\kernel\Documentation\power\qpnp-linear-charger.txt---下面是学习此文件\kernel\Documentation\devicetree\bindings\power\qpnp-linear-charger.txt1. 简介The QPNP linear charger drive…

岳阳鸿蒙数学培优阶梯训练,鸿蒙应用-呼吸训练app部分练习展示(开始)

本帖最后由 李洋水蛟龙 于 2020-12-20 18:11 编辑1.在主页面添加一个按钮并响应点击事件效果显示&#xff1a;图片1.png (404.17 KB, 下载次数: 0)2020-12-10 17:53 上传点击按钮“点我”下方便会显示“我被点击了”说明点击事件已完成代码如下&#xff1a;Index.hml文件中Hell…

android日期选择滚轮框架,GitHub - liwenzhi/wheelview: 滚轮效果的View,日期选择器

#wheelview滚动效果的View这段时间需要用到一个时间选择器&#xff0c;但是不能使用日期对话框&#xff0c;因为它是筛选条件框架下的&#xff0c;只能是View&#xff01;这个WheelView改造后可以达到要求&#xff01;这个wheelview框架使用的类不多&#xff0c;就几个&#xf…

大学计算机基础知识点图文,大学计算机基础知识点超详细总结

大学计算机基础知识点超详细总结 第一章 计算机及信息技术概述1. 电子计算机的发展历程①1946 年 2 月由宾夕法尼亚大学研制成功的 ENIAC 是世界上第一台电子数字计算机。 “诞生了一个电子的大脑” 致命缺陷&#xff1a;没有存储程序。②电子技术的发展促进了电子计算机的更新…

js复制html到粘贴板,用clipboard.js实现纯JS复制文本到剪切板

以前很多人都是用ZeroClipboard.js来实现网页复制内容&#xff0c;火端也是用它。ZeroClipboard是利用flash来实现的&#xff0c;ZeroClipboard兼容性很好&#xff0c;但是由于现在越来越多的浏览器不支持flash&#xff0c;导致一些没法正常使用了。今天火端开始使用clipboard.…

计算机设备的存放,计算机硬件储存设备与网络储存的发展现状

计算机的出现&#xff0c;改变了人们的生活和生产&#xff0c;而计算机硬件技术的发展&#xff0c;则为计算机储存开辟了新的发展方向和途径。而随着时代的进步&#xff0c;计算机储存技术的发展也是日新月异&#xff0c;现在我们所使用的云储存技术&#xff0c;就是储存技术发…

计算机键盘没有fn,键盘Fn键失灵怎么解决?键盘Fn键失灵的修复方法

电脑键盘是电脑输入设备中最常用的设备之一&#xff0c;也是大家使用最频繁的的设备。其实键盘Fn键占据着很大分量,Fn键能够实现很多功能,如控制音量、打开关闭摄像头、屏幕亮度调节等。如果Fn键失灵的话,那就会对电脑造成很大的影响&#xff0c;有什么办法修复&#xff1f;下面…

网站的服务器分哪几种,服务器有哪几种分类?_服务器可分为四种类型

办事器能够按使用分&#xff1a;OA办事器、数据库办事器、流媒体办事器、高机能计较办事器、逛戏办事器等。软盘接口是软盘取从机系统间的毗连部件&#xff0c;感化是正在软盘缓存和从机内存之间传输数据。分歧的软盘接口决定灭软盘取计较机之间的毗连速度&#xff0c;正在零个…

英雄联盟服务器维护3月17,英雄联盟将于3月17日凌晨2点开始进行全区停机维护...

原标题&#xff1a;英雄联盟全区停机维护公告英雄联盟将于3月17日凌晨2点开始进行全区停机维护&#xff0c;公告如下&#xff1a;我们将于3月17日2点开始全区停机维护以进行后台服务升级&#xff0c;预计在凌晨1点关闭排位赛入口&#xff0c;不会影响正在进行中的排位赛。预计停…

网站服务器时间秒杀,Javascript实现商品秒杀倒计时(时间与服务器时间同步)...

现在有很多网站都在做秒杀商品&#xff0c;而这其中有一个很重要的环节就是倒计时。关于倒计时&#xff0c;有下面几点需要注意&#xff1a;1.应该使用服务器时间而不是本地时间(本地时间存在时区不同、用户自行设置等问题)。2.要考虑网络传输的耗时。3.获取时间时可直接从AJAX…

i7 8700 服务器系统,i7 8700k 云服务器

i7 8700k 云服务器 内容精选换一换您可以在几分钟之内快速获得基于公有云平台的弹性云服务器设施&#xff0c;并且这些设施是弹性的&#xff0c;可以根据需求伸缩。该任务指导用户如何创建支持IB网卡的弹性云服务器&#xff0c;包括管理控制台方式和基于HTTPS请求的API(Applica…

(教程)2020最新windows10/anaconda/pytorch-gpu环境配置(附CUDA/cuDNN配置)

&#xff08;教程&#xff09;2020最新windows10/anaconda/pytorch-gpu环境配置&#xff08;附CUDA/cuDNN配置&#xff09; 环境&#xff1a;windows10 nvidia 165ti 1. 安装anaconda3&#xff0c;自行安装 https://www.anaconda.com/download/ 安装完成后&#xff0c;配置…

信息论 哈夫曼编码 与 菲诺编码的实现(对一幅BMP格式的灰度图像(个人 证件照片)进行二元霍夫曼编码和译码。并进行编码效率的计算,对一幅BMP格式的灰度图像进行二 元Fano编码、译码 )

信息论 哈夫曼编码 与 菲诺编码的实现&#xff08;对一幅BMP格式的灰度图像&#xff08;个人 证件照片&#xff09;进行二元霍夫曼编码和译码。并进行编码效率的计算&#xff0c;对一幅BMP格式的灰度图像进行二 元Fano编码、译码 &#xff09; 原始图片 灰度处理 编码生成的…

教你如何使用hexo以及nginx、github搭建属于自己的博客(操心的妈妈级教学)

教你如何使用hexo以及nginx、github搭建属于自己的博客&#xff08;妈妈级教学&#xff09; ~~ 1.解释一下你要的服务器的效果以及对应的操作 ~~ 首先你要有自己的一台服务器&#xff0c;可以是云服务器&#xff0c;或者你可以用自己的电脑作为服务器&#xff0c;&#xff0…

(菜鸟入门)使用pytorch框架实现前馈神经网络

前馈神经网络 常见的前馈神经网络有感知机&#xff08;Perceptrons&#xff09;、BP&#xff08;Back Propagation&#xff09;网络等。前馈神经网络(FNN)是人工智能领域中最早发明的简单人工神经网络类型。各神经元分层排列。每个神经元只与前一层的神经元相连。接收前一层的…

Windows下如何如何将项目上传至GitHub?

安装git客户端 进入官网&#xff0c;点击右侧下载windows版本的软件包 如果下载慢的话&#xff0c;给一个传送门&#xff0c;可以快速下载&#xff1a; 双击安装 一直点击下一步就可&#xff0c;安装位置可以自己选择一下 Github创建仓库 填写项目名称以及ba…

(pytorch-深度学习系列)pytorch卷积层与池化层输出的尺寸的计算公式详解

pytorch卷积层与池化层输出的尺寸的计算公式详解 注&#xff1a;这篇blog写的不够完善&#xff0c;在后面的CNN网络分析padding和stride详细讲了公式&#xff0c;感兴趣的可以移步这里&#xff1a;卷积神经网络中的填充(padding)和步幅(stride) 要设计卷积神经网络的结构&…

idea创建springboot项目,一直在reading pom.xml

problem&#xff1a;遇到的问题 idea创建springboot项目&#xff0c;一直在reading pom.xml 解决方法有三种&#xff1a; &#xff08;1&#xff09;修改windows配置文件 c;\windows\System32\drivers\etc\hosts将12.0.0.1 localhost前的注释符号#去掉 &#xff08;2&#x…

springboot 项目实战 基本框架搭建(IDEA)

springboot 项目实战 基本框架搭建&#xff08;IDEA&#xff09; IDEA下载 我使用的是破解的专业版IDEA&#xff0c;使用权一直到2089年&#xff1a; 下载IDEA: 下载processional版本&#xff0c;然后百度搜索激活码即可概率激活&#xff0c;如果你不成功就多找几个激活码 配…

使用IDEA 连接mysql数据库,执行sql指令

使用IDEA 连接mysql数据库&#xff0c;执行sql指令 1 配置项目的SQL依赖 首先参考这篇博文&#xff0c;创建springboot的基本框架 在创建项目的过程中&#xff0c;需要选择SQL相关的依赖&#xff0c;如下&#xff1a; SQL勾选&#xff1a;MySQL Driver&#xff0c;JDBC API …