初步编写IDEA\AndroidStudio翻译插件的方法

声明:作者是根据 Hongyang的博客自己实践之后,根据自己的理解写的,有什么不对的地方还望指正。
先放两张效果图

一、准备

  • 由于AndroidStudio不具备开发插件的功能,需要安装IDEA
  • 翻译使用的是有道的翻译接口,需要申请,接口申请的网址点这里
  • json解析使用的是GSON

二、创建工程

在此处创建的plugin工程,如下图所示

填写完工程名之后, 创建的工程结构如下所示

其中plugin.xml就和j2ee中web.xml功能类似,是配置插件属性的地方。

三、撸代码

首先,new一个Action,在弹出界面简单填写类的信息,如下图

其中第一部分是类相关的信息,ActionID表示一个独一无二的名字,就像Android清单文件中的包名一样。
第二部分是将这个功能添加到哪个菜单中去,当前选择的是添加到Edit菜单中并且作为第一个子菜单。
第三部分是这个功能的快捷键,可将光标置于输入框内,点击键盘进行输入
可以看到在生成的类中有public void actionPerformed(AnActionEvent e) 这个方法,关键的地方就在这个方法中,在IDE中几乎所有操作都可以在此方法中捕捉到。如下图

首先获取选中的文字,调用以下api

 final Editor mEditor = e.getData(PlatformDataKeys.EDITOR);
  if (null == mEditor) {
   return;
  }
  SelectionModel model = mEditor.getSelectionModel();
  final String selectedText = model.getSelectedText();
  if (TextUtils.isEmpty(selectedText)) {
   return;
  }

获取到选中的文字之后,就可以调用申请到的有道翻译接口进行翻译,要翻译的文本,必须是UTF-8编码,字符长度不能超过200个字符,需要进行urlencode编码。翻译完成之后就可以以一个类似popupWindow的窗口将接口展示出来了。

private void showPopupBalloon(final Editor editor, final String result) {
  ApplicationManager.getApplication().invokeLater(new Runnable() {
   public void run() {
    JBPopupFactory factory = JBPopupFactory.getInstance();
    factory.createHtmlTextBalloonBuilder(result, null, new JBColor(new Color(186, 238, 186), new Color(73, 117, 73)), null)
      .setFadeoutTime(5000)
      .createBalloon()
      .show(factory.guessBestPopupLocation(editor), Balloon.Position.below);
   }
  });
 }

点击绿色运行按钮,测试成功后就可以生成安装包了。在Build菜单中选择 Prepare Plugin Module ‘your project name' For Deployment就可以生成安装包了。
我只是为了自己用,所以没有在plugin.xml文件中添加更多的详细信息,至于怎么发布到插件库,还请大家自行google,下面是完整的代码。点击这里下载我编译好的插件,zip格式的。
完整代码如下:
action 类

import com.google.gson.Gson;
import com.intellij.openapi.actionSystem.AnAction;
import com.intellij.openapi.actionSystem.AnActionEvent;
import com.intellij.openapi.actionSystem.PlatformDataKeys;
import com.intellij.openapi.application.ApplicationManager;
import com.intellij.openapi.editor.Editor;
import com.intellij.openapi.editor.SelectionModel;
import com.intellij.openapi.ui.popup.Balloon;
import com.intellij.openapi.ui.popup.JBPopupFactory;
import com.intellij.ui.JBColor;
import org.apache.http.util.TextUtils;

import java.awt.*;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLEncoder;

/**
 * Created by huangyuan on 16-7-16.
 */
public class TranslateAction extends AnAction {

 //有道翻译接口
 private String translateUrl = "http://fanyi.youdao.com/openapi.do?keyfrom=AS-TranslatePlugin&key=your key&type=data&doctype=json&version=1.1&q=%s";

 public void actionPerformed(AnActionEvent e) {
  final Editor mEditor = e.getData(PlatformDataKeys.EDITOR);
  if (null == mEditor) {
   return;
  }
  SelectionModel model = mEditor.getSelectionModel();
  //获取选中的文字
  final String selectedText = model.getSelectedText();
  if (TextUtils.isEmpty(selectedText)) {
   return;
  }

//  Messages.showMessageDialog(selectedText, "选中的文字", Messages.getInformationIcon());
  TranslateBean translateBean = doTranslate(selectedText);
  showPopupBalloon(mEditor,translateBean.toString());

 }

 /**
  *
  * @param translateText 需要翻译的文本
  * @return TranslateBean 翻译完成后转换为对象
  * 调用翻译接口,将返回的数据用Gson封装为对象
  */
 private TranslateBean doTranslate(String translateText) {
  Gson gson = new Gson();
  InputStream is = null;
  StringBuffer resultData = new StringBuffer();
  try {
   URL url = new URL(String.format(translateUrl, URLEncoder.encode(translateText,"utf-8")));
   HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
   httpURLConnection.setDoInput(true); //允许输入流,即允许下载
   httpURLConnection.setDoOutput(true); //允许输出流,即允许上传
   httpURLConnection.setUseCaches(false); //不使用缓冲
   httpURLConnection.setRequestMethod("GET"); //使用get请求
   is = httpURLConnection.getInputStream(); //获取输入流,此时才真正建立链接
   InputStreamReader isr = new InputStreamReader(is);
   BufferedReader bufferReader = new BufferedReader(isr);
   String inputLine = "";
   while((inputLine = bufferReader.readLine()) != null){
    resultData.append(inputLine);
   }

   System.out.println(resultData.toString());

   TranslateBean translateBean = gson.fromJson(resultData.toString(), TranslateBean.class);
   return translateBean;
  } catch (MalformedURLException e) {
   e.printStackTrace();
  } catch (IOException e) {
   e.printStackTrace();
  }

  return null;
 }

 /**
  *
  * @param editor Edit
  * @param result 要展示的文字
  * 以类似popupwindow的形式展示,别问我为什么这么写,我也不知道,我是抄的api
  */
 private void showPopupBalloon(final Editor editor, final String result) {
  ApplicationManager.getApplication().invokeLater(new Runnable() {
   public void run() {
    JBPopupFactory factory = JBPopupFactory.getInstance();
    factory.createHtmlTextBalloonBuilder(result, null, new JBColor(new Color(186, 238, 186), new Color(73, 117, 73)), null)
      .setFadeoutTime(5000)
      .createBalloon()
      .show(factory.guessBestPopupLocation(editor), Balloon.Position.below);
   }
  });
 }
}

TranslateBean

import java.util.List;

/**
 * Created by huangyuan on 16-7-17.
 */
public class TranslateBean {

 private BasicBean basic;
 private String query;
 private int errorCode;
 private List<String> translation;
 private List<WebBean> web;

 public BasicBean getBasic() {
  return basic;
 }

 public void setBasic(BasicBean basic) {
  this.basic = basic;
 }

 public String getQuery() {
  return query;
 }

 public void setQuery(String query) {
  this.query = query;
 }

 public int getErrorCode() {
  return errorCode;
 }

 public void setErrorCode(int errorCode) {
  this.errorCode = errorCode;
 }

 public List<String> getTranslation() {
  return translation;
 }

 public void setTranslation(List<String> translation) {
  this.translation = translation;
 }

 public List<WebBean> getWeb() {
  return web;
 }

 public void setWeb(List<WebBean> web) {
  this.web = web;
 }

 public static class BasicBean {
  private List<String> explains;
  private String phonetic;

  public String getPhonetic() {
   return phonetic;
  }

  public void setPhonetic(String phonetic) {
   this.phonetic = phonetic;
  }

  public List<String> getExplains() {
   return explains;
  }

  public void setExplains(List<String> explains) {
   this.explains = explains;
  }
 }

 public static class WebBean {
  private String key;
  private List<String> value;

  public String getKey() {
   return key;
  }

  public void setKey(String key) {
   this.key = key;
  }

  public List<String> getValue() {
   return value;
  }

  public void setValue(List<String> value) {
   this.value = value;
  }

 }

 @Override
 public String toString() {

  StringBuffer webStringBuffer = new StringBuffer();

  for(int i =0;i<web.size();i++)
  {
   webStringBuffer.append(web.get(i).getKey() +":\t");
   for(int j =0 ;j<web.get(i).getValue().size();j++)
   {
    webStringBuffer.append(web.get(i).getValue().get(j));
   }
   webStringBuffer.append("\n");
  }

  StringBuffer translateBuffer = new StringBuffer();
  for(int i = 0;i<basic.getExplains().size();i++)
  {
   translateBuffer.append(basic.getExplains().get(i) +"\n");
  }
  return query +"\n" + basic.getPhonetic() +"\n" + translateBuffer.toString() +"\n网络释义+\n" + webStringBuffer.toString();
 }
}

到此这篇关于初步编写IDEA\AndroidStudio翻译插件的文章就介绍到这了,更多相关IDEA AndroidStudio翻译插件内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 在Android Studio中Parcelable插件的简单使用教程

    在Android Studio中,你可以很快速的使用Parcelable插件进行实体类的序列化的实现,使用该插件后,你的实体类可以快速的实现Parcelable接口而不用写额外的代码.因为该插件会帮你快速的生成必须提供的方法,可以说是很高效率的了. 首先需要下载该插件: 在File->Setting->Plugins里的搜索框内输入内容:android parcelable code generator,然后自己下载好重启studio即可使用该插件了. 下载插件界面: 重启studio: 点击

  • 为Android Studio编写自定义Gradle插件的教程

    Google已经建议Android开发全部转向Android Studio开发,Android Studio 是使用gradle编译.打包的,那么问题来了,gradle可是有一堆东西...,为了彻底了解gradle,今天就来学习下如何写自己的gradle插件(当然插件源码是使用groovy写的),先看如下代码目录: 如上图所示,plugin目录是插件源码目录,sample是用来测试插件的. 1.在目录plugin/src/main/groovy/com/micky/gradle/下新建插件类My

  • Java Idea TranslationPlugin翻译插件使用解析

    开发中,对于不经常使用英语的同学来说,对类,变量,方法想取一个合适的名字,此时发现自己的词汇早已还给老师 ,怎么办,这个插件能帮到你~ 一.安装 点击File-- Settings--Plugins设置界面,安装Translation插件. 二.使用 2.1 翻译单词 选中单词,右击菜单里面有"Translate". 2.2 替换单词 2.3 文本翻译 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们.

  • 如何使用idea里面自带的翻译插件

    打开idea 点击左上角file 点击Settings 然后在弹出页面里点击Plugins 在右边的搜索框中搜索Translation 然后找到图中我标中的那个插件 点击Installed下载安装 然后根据提示重启idea就好啦 下面我们来试试效果 在控制台中选择报错信息 然后点击右键我们可以看到刚刚下载的插件 然后点击,等他加载好,我们就能看到中文翻译啦 到此这篇关于idea里面自带的翻译插件的文章就介绍到这了,更多相关idea翻译插件内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以

  • 初步编写IDEA\AndroidStudio翻译插件的方法

    声明:作者是根据 Hongyang的博客自己实践之后,根据自己的理解写的,有什么不对的地方还望指正. 先放两张效果图 一.准备 由于AndroidStudio不具备开发插件的功能,需要安装IDEA 翻译使用的是有道的翻译接口,需要申请,接口申请的网址点这里 json解析使用的是GSON 二.创建工程 在此处创建的plugin工程,如下图所示 填写完工程名之后, 创建的工程结构如下所示 其中plugin.xml就和j2ee中web.xml功能类似,是配置插件属性的地方. 三.撸代码 首先,new一

  • jQuery创建自己的插件(自定义插件)的方法

    但必须知道,这些插件不是自己凭空产生的,它们是由开发人员编写.测试并完善的,这些人员为 jQuery 社区奉献了自己的业余时间.我们做这些都是免费的,是出于对自己代码的热爱.本文主要关注您如何回报这个伟大的社区,即如何编写自己的插件并上传到 jQuery 的插件页面.这可以让所有人使用您创建的插件,可以让整个 jQuery 开发社区变得更好.今年您也做出自己的贡献吧. 在编写本文中的插件时,我发现插件的创建过程以及用来创建它的框架非常简单明了.困难的地方在于想一些其他人还没有做过的事情,并编写一

  • 在Linux中使用Vundle管理Vim插件的方法

    前言 毋庸置疑,Vim 是一款强大的文本文件处理的通用工具,能够管理系统配置文件和编写代码.通过插件,Vim 可以被拓展出不同层次的功能.通常,所有的插件和附属的配置文件都会存放在 ~/.vim 目录中.由于所有的插件文件都被存储在同一个目录下,所以当你安装更多插件时,不同的插件文件之间相互混淆.因而,跟踪和管理它们将是一个恐怖的任务.然而,这正是 Vundle 所能处理的.Vundle,分别是 Vim 和 Bundle 的缩写,它是一款能够管理 Vim 插件的极其实用的工具. Vundle 为

  • 基于Python开发chrome插件的方法分析

    本文实例讲述了基于Python开发chrome插件的方法.分享给大家供大家参考,具体如下: 谷歌Chrome插件是使用HTML.JavaScript和CSS编写的.如果你之前从来没有写过Chrome插件,我建议你读一下这个.在这篇教程中,我们将教你如何使用Python代替JavaScript. 创建一个谷歌Chrome插件 首先,我们必须创建一个清单文件:manifest.json. { "manifest_version": 2, "name": "Py

  • Vue项目vscode 安装eslint插件的方法(代码自动修复)

    ESlint:是用来统一JavaScript代码风格的工具,不包含css.html等. 方法和步骤: 通常情况下vue项目都会添加eslint组件,我们可以查看webpack的配置文件package.json查看,也可以查看工程下是否有.eslintrc.js和.eslintignore查看到eslint是否开启. 当我们编写不符合eslint规范的代码时,启动项目会报错,比如 这个时候可以安装vscode eslint插件,就可以自动检测不符合规范的代码.打开vscode左侧扩展面板,搜索es

  • 关于vue3编写挂载DOM的插件问题

    vue3 跟 vue2 相比,多了一个 app 的概念,vue3 项目的创建也变成了 // main.js import { createApp } from 'vue' import App from './App.vue' import ElementPlus from 'element-plus' const app = createApp(App) app.use(ElementPlus) // 使用饿了么框架 app.mount('#app') 所以 Vue.extend 也没有了.

  • 关于Pycharm配置翻译插件Translation报错更新TTK失败不能使用的问题

    解决IDEA翻译插件Translation报错更新TTK失败不能使用有好久一段时间没有用idea的插件Translation,升级后使用翻译,竟然翻译失败...网上搜索无数办法都没有效果:1.卸载了以后重新装但是没用:无效!2.Translation配置问题去取消勾选项,还是无效! 还是无效,其实勾选不勾选都用一样3.修改Hots文件:还是无效! [修改C:\Windows\System32\drivers\etc 下hosts文件, 添加 203.208.40.66 translate.goo

  • Extjs表单输入框异步校验的插件实现方法

    一.效果如图所示 特点: 1.异步后台校验不会对用户操作产生阻塞感: 2.可在用户停止输入后自动校验,避免频繁进行无谓的后台校验: 3.以插件方式实现,方便使用: 二.插件源码如下: /** * Created by jiawenjun on 2016/10/19. */ Ext.define('Ext.ux.plugins.FieldAjaxVerify',{ extend: 'Ext.AbstractPlugin', alias: 'plugin.fieldajaxverify', buff

  • JavaScript通过字典进行字符串翻译转换的方法

    本文实例讲述了JavaScript通过字典进行字符串翻译转换的方法.分享给大家供大家参考.具体分析如下: 这里实际上就是先设置一个对照的字典,然后通过翻译函数,从字典中找到相应的键值.需要在JavaScript 1.8以上版本使用 函数定义如下: function CreateTranslator(translationTable) function(s) s.replace( new RegExp([k for (k in translationTable)].join('|'), 'g'),

  • JS导出PDF插件的方法(支持中文、图片使用路径)

    在WEB上想做一个导出PDF的功能,发现jsPDF比较多人推荐,遗憾的是不支持中文,最后找到pdfmake,很好地解决了此问题.它的效果可以先到http://pdfmake.org/playground.html查看.在使用过程中,还发现图片的插入是相对繁琐的一件事. 针对这些问题,本文的主要内容可分为三部分: •pdfmake的基本使用方法: •如何解决中文问题; •如何通过指定图片地址插入图片. pdfmake的基本使用方法 1.包含以下两个文件 <script src="build/

随机推荐

其他