AS插件开发之Excel转JavaBean字段
来源:互联网 发布:淘宝企业账号注册流程 编辑:程序博客网 时间:2024/06/03 06:56
..
展示效果如上图所示。
我们就简单说一下AS或者是说IDEA的插件开发。我们可能都用过一些AS的插件,我比较喜欢也执迷其中的就是一些自动生成代码的插件,解放双手的感觉让人欲罢不能。
1.环境搭建略过,也就IEDA这个软件
2.我们使用IEDA新建一个插件项目:
3.新建一个继承自AnAction的类,并重写
public void actionPerformed(AnActionEvent e) {}
actions的配置文件交代一些基本信息,新建的时候会提供可视化操作界面也可在xml中修改。交代了一些信息,入口Action,
插件的id,插件的名字,插件所在的菜单目录,插件的描述等。
<actions> <!-- Add your actions here --> <action id="addfieldformexcel" class="MainAction" text="addStringFieldFormExcel0.9.0" description="addStringFieldFormExcel0.9.0"> <add-to-group group-id="WindowMenu" anchor="first"/> </action> </actions>
这个Action的actionPerformed也就是插件程序的入口也就是类似Main函数吧。
我们就再这个Action里声明一个JFrom窗体程序剩下的页面逻辑就交给窗体程序处理了并搞一个接口等待点击确定按钮的回调进行插入字段的操作:
MainFrom test11=new MainFrom(new MainFrom.OnClickListener() { @Override public void onClick(String s,String type) { String[] ss=s.split("\n"); BaseBuilder builder = new FieldBuilder(); builder.build(e, ss,type); } });
4.那么我们是如何玩这个窗体程序的呢,其实跟之前的java窗体程序一模一样,那就玩起来吧。
不知道老铁们是不是还记得当年那个东南西北布局,还是有JPanel啥的。其实跟安卓的布局是一样的,一个布局就是提供一种Layout的规则,然后排列控件。
比如我们这个插件需要一个确定按钮,一个组选择器选择public还是private然后就是一个输入框来接受Excel的内容。
我们就拖拽一个形成上图的样子,给控件赋予field name就会自动在代码里生成控件变量不用findviewbyid了哈哈
在这里搞一个接口回调,起个跟安卓点击事件一样的名字找找感觉:
public interface OnClickListener { void onClick(String s,String type); }
button点击事件并触发接口回调:
@Override public void actionPerformed(ActionEvent arg0) { System.out.print("点击了按钮呢"); String s = textArea1.getText(); if (privateRadioButton.isSelected()) onClickListener.onClick(s,"private"); else onClickListener.onClick(s,"public"); dispose(); } });
选择按钮组:
ButtonGroup sexRadioButtonGroup = new ButtonGroup(); // 创建一个选按钮组对象 sexRadioButtonGroup.add(privateRadioButton); // 将单选按钮对象添加到按钮组对象中 sexRadioButtonGroup.add(publicRadioButton); // 将单选按钮对象添加到按钮组对象中
5.处理输入字符串:
其实思路很简单,就是根据Excel粘贴进来的字符特性,进行分割处理。并在当前输入类中加入Field。
ArrayList<PsiField> psiFields=new ArrayList<>(); for (int i = 0; i <ss.length ; i++) { String []sss=ss[i].split("\t"); String s = type+" " + sss[1] + " " + sss[0] + "; // " + sss[2]; PsiField field = factory.createFieldFromText(s, psiClass); psiFields.add(field); } for (int i = 0; i < psiFields.size(); i++) { psiClass.add(psiFields.get(i)); }
6.大功告成。我们编译以下,发现是又启动了一个IEDA,当然这个是在开发调试模式。编译结束后我们在根目录下会自动生成插件的jar,也就是可以作为插件引入的jar。欢迎体验哈~
Download :https://github.com/AndroidMsky/AddFieldFromExcel/blob/master/AddFieldFromExcel.jar
AS插件开发很强大,如果为自己项目制定独自的开发插件,将会使安卓开发事半功倍,笔者也是刚刚看了一些API才做出这个插件,后续有机会也会做出更加复杂的插件。
插件源码地址:
https://github.com/AndroidMsky/AddFieldFromExcel
觉得有用欢迎点个star,也希望大家提出改进的意见,共同完善这个AddFieldFromExcel插件
哪里可以找到我:
我的Github: https://github.com/AndroidMsky
我的博客主页: http://blog.csdn.net/androidmsky
欢迎加作者自营安卓开发交流群:
308372687
- AS插件开发之Excel转JavaBean字段
- Mybatis插件之generatorConfig自动生成JavaBean之不使用默认的驼峰式设计字段
- 浅谈C/C++ 开发Excel插件之操作excel
- javaweb开发之javaBean
- Excel插件开发
- Excel插件开发
- Excel 插件开发
- JavaWeb开发之十三:Javabean
- JAVA WEB开发之JavaBean
- 浅谈C/C++ 开发Excel插件之创建项目
- 浅谈C/C++ 开发Excel插件之任务窗格
- 提高开发效率----as插件(持续更新)
- 安卓开发 As插件解放双手
- AS之NDK开发流程
- Java开发之-debug as
- 使用xla开发Excel插件
- C#-Excel插件开发总结
- AS插件
- TP3.2.3和jQuery跨域请求源码。。。
- linux串口基本编程
- Linux下安装Gviz
- 有效自定义rightbatbuttonitem样式及其与屏幕的边距
- vim
- AS插件开发之Excel转JavaBean字段
- webService 远程调用,客户端自动生成操作
- VC++各种数据类型转换
- DPDK之(九)——收发包分析
- JVM性能优化, Part 2 ―― 编译器
- Systick分析
- windows关闭windows正在检查该问题的解决方案
- hibernate 学习细节
- 二叉搜索树的判断 leetcode原题