从零单排之 IDEA 插件开发,没你想的那么难(2)

!!!最近突然想起这个系列的文章鸽了好久,重新看了下,发现开源中国的摸鱼模块已经没了,所以demo可能跑不通了,至于下一篇什么时候,只能说关注敬请期待

开头还是啰嗦几句,此文章是一个系列的文章,上一篇可以在https://www.jianshu.com/p/c18d1eacdb42处找到,欢迎阅读点赞。

依然是我们的定位赛,依然是一个小例子,此次的例子比上一篇文章增加了一点点的难度,代码在https://gitee.com/yuanzizhenxin/PluginDemo,对应分支为v2,以后所有的例子对应的代码我都会放到对应的分支下,会把例子之外多余的代码删掉,方便大家进行阅读,不被其他代码干扰到,好了,下面还是先介绍一些基本的概念,然后用例子去实践插件开发。

1、技术简介

(1)swing:我们通过搜索引擎可以查到此技术其实是一种java的客户端gui解决方案,跟他同类的还有javafx,说白点就是做可以看到内容的技术,但是目前我所知道的,此类技术的市场已经很小了,如果不是因为要开发插件,可能我都不会去接触此类技术,当然我也不建议大家花费很长时间去学,需要什么只要找万能的搜索引擎搜索代码示例就行了(某度跳过广告也凑活还能用),我也会在用到的swing组件上写一些内容,由于本人也只是用到啥看啥,所以我只能讲解入门,还没法讲到放弃(狗头)。

(2)jsoup:此框架是用来解析html内容的,它可以通过类似css的语法获取html内容中的元素,而我们今天的这个例子就用到此框架进行解析html片段内容。具体的教程可以参考 https://www.cnblogs.com/zhangyinhua/p/8037599.html,后边看情况如果需要我会整理一份实战的文档(flag先立下来)。

(3)展示框:此次实例我们将要实现一个弹窗,弹窗内容是从开源中国获取到的内容,其中牵扯到一个做弹窗必须继承的类,叫做com.intellij.openapi.ui.DialogWrapper,记住此类是idea插件里面弹窗要继承的抽象类,重写createCenterPanel方法就可以。

2、实例开始

介绍完几个东西之后,让我们来看看插件示例有啥内容吧

(1)功能介绍:看开源中国网站的用户摸鱼。

在开源中国的官方首页右侧有个动弹的功能,那我们怎么在敲代码的时候能看到别人摸鱼岂不是很有意思,ok,需求就是这样,怎么实现看我的。

(2)需求分析:看到这个需求,需要先分析需求,我个人习惯会先抽象化需求,此需求是从别人的网站获取内容展示在idea中,所以三个需求点如下,其中b和c需求可以考虑合并,这里我没有进行合并,因为不同网站内容获取的刷新机制是不一样的,有的需要轮询,有的是websocket。

a、获取内容-----开源中国官方首页右侧的动弹获取

b、展示内容-----展示在idea某个地方

c、刷新内容-----实时刷新最新的摸鱼动态

(3)需求代码实战过程

首先需要去开源中国官网看下动弹是怎么实现的,打开chrome并访问https://www.oschina.net/,看到右侧有个动态,见下图


开源中国首页

点击F12打开调试工具,选择network并刷新当前页面,然后就要瞪大眼睛一个个的地址去猜,没错,这里就是个体力活,然后成功定位到这个地址(https://www.oschina.net/widgets/_index_tweets_list?type=ajax&tab=newestTweet&nocache=1587199611761)


可能会疑惑怎么找到的,这个分很多情况,写爬虫多的人应该很容易能找到,如果对这种课题比较感兴趣,可以反馈给我,我可以写个这方面的专栏内容。

找到这个地址之后,发现这个地址的返回结果是一个html的结果片段,那这种html片段该怎么处理呢?这里就引出了刚介绍的jsoup,使用jsoup就可以将html片段进行解析生成一个dom树的结构。具体代码可以看com.jd.demo.rpc.OpenSourceHttp#getInfo,已经注释写上了。

当我们能获取动弹内容后,接下来就是要展示出来了,这个就需要用到刚说的com.intellij.openapi.ui.DialogWrapper类了,具体代码见com.jd.demo.ui.OpenSourceList类,简单说下这个类,首先这个类是继承了DialogWrapper抽象类,并覆盖重写了createCenterPanel方法,说白点就是中间部分是什么样子就看这个方法了,见下图部分,中间部分就是createCenterPanel方法需要返回的UI的内容部分,此外还有两个方法,去代码中看吧。


Dialog示例图

(4)最后说明:

A、v2分支中的action入口我放在了顶部Build菜单下面第一个,大家可以参考plugin配置文件去研究一下位置是怎么摆放的。

B、在dialog中牵扯了两个类,一个是JTextArea,还有一个是JScrollPane,这个是swing相关的部分,这个放到下一篇文章单独讲一下。

C、我没有实现实时刷新的功能,大家可以尝试自己改一下目前我的代码,实现实时刷新的能力。

最后的最后自我介绍一下,我是梦游神,就职于京东,我们下一篇文章见!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350