重开发AndroidStudio 小插件

时隔很久之后,重新开发一个AS上的脚手架,记录过程

1、下载安装idea ,官网社区版下载
2、新建plugin project

打开 IDE—new Project 选择IntelliJ Platform Plugin,注意 Project SDK的配置


image.png
3、根据提示,输入必要信息,一路Next ,完成创建后,生成的项目结构如下图:
image.png
4、编写插件

有两种方式
4.1、src文件夹右击创建一个Action。Action是一个处理插件交互行为的类。(未实现,不做过多描述)

4.2、我采用的方式,手动添加对应类:

4.2.1、src文件夹下创建,对应的TestPlugin类

package con.test.plugin

import com.intellij.openapi.actionSystem.AnAction
import com.intellij.openapi.actionSystem.AnActionEvent
import com.intellij.openapi.actionSystem.CommonDataKeys
import com.intellij.openapi.project.Project
import com.intellij.openapi.ui.Messages
import com.intellij.openapi.vfs.VirtualFile

class TestPlugin:AnAction("new-plugin") {

    var project: Project? = null
    var selectGroup: VirtualFile? = null

    override fun actionPerformed(e: AnActionEvent) {

        project = e.project
        val className =
                Messages.showInputDialog(project, "please input activity name", "NewMvvmActivity", Messages.getQuestionIcon())
        selectGroup = CommonDataKeys.VIRTUAL_FILE.getData(e.dataContext)
        if (className == null || className == "") {
            print("没有输入类名")
            return
        }

    }
}

4.2.2、编辑plugin.xml

<idea-plugin>
   <id>com.your.company.unique.plugin.id</id>
   <name>test-new-plugin</name>
   <version>5.0</version>
   <vendor email="support@yourcompany.com" url="http://www.yourcompany.com">YourCompany</vendor>

   <description><![CDATA[
     Enter short description for your plugin here.<br>
     <em>most HTML tags may be used</em>
   ]]></description>

   <change-notes><![CDATA[
     Add change notes here.<br>
     <em>most HTML tags may be used</em>
   ]]>
   </change-notes>

   <!-- please see https://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/build_number_ranges.html for description -->
   <idea-version since-build="173.0"/>

   <!-- please see https://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/plugin_compatibility.html
        on how to target different products -->
   <depends>com.intellij.modules.platform</depends>

   <extensions defaultExtensionNs="com.intellij">
       <!-- Add your extensions here -->
   </extensions>

   <actions>
       <!-- Add your actions here -->
       <group id="com.test.plugin.action.id" text="NewPlugin" description="new plugin">
           <add-to-group group-id="NewXml" anchor="before" relative-to-action="NewHtmlFile"/>
           <action id="NewPlugin.activity.action" class="con.test.plugin.TestPlugin" text="Text _name"
                   description="new plugin"/>
       </group>
   </actions>

</idea-plugin>

此时运行 run plugin ,看到如下截图:


image.png

点击new-plugin 便会有TestPlugin类内编写的弹窗出现,剩下的便是在此类内编写自己的逻辑了。

参考:
https://www.jianshu.com/p/cb3e7c7d694b
https://cloud.tencent.com/developer/article/1780118

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容