5分钟实现 Java 使用 HanLP提取关键词短语 ;Vue实现词云图,词云图自定义形状,关键词绑定事件。

1.Java使用HanLp提取关键词短语

首先HanLp是开源免费的,可以直接引入依赖

  <dependency>
            <groupId>com.hankcs</groupId>
            <artifactId>hanlp</artifactId>
            <version>portable-1.8.4</version>
  </dependency>

小伙伴们如果有兴趣可以查看官方文档,写的非常详细,我这里就是用的 关键词提取的功能

示例代码如下:

String content = "世嘉:《索尼克:超级巨星》销量不佳与《马里奥惊奇》撞车有关";
List<String> keywordList = HanLP.extractKeyword(content, 2);
System.out.println(keywordList);

 官方文档:

https://github.com/hankcs/HanLP/tree/1.x#14-%E5%85%B3%E9%94%AE%E8%AF%8D%E6%8F%90%E5%8F%96icon-default.png?t=N7T8https://github.com/hankcs/HanLP/tree/1.x#14-%E5%85%B3%E9%94%AE%E8%AF%8D%E6%8F%90%E5%8F%96

2.Vue实现词云图 

先看效果:

那么我们如何实现如上的词云图呢?直接上代码:

setWordChart = function (detail) {
    const that = this;
    if (that.$refs.wordChart) {
      // 如果已经初始化,则销毁图表实例
      echarts.dispose(this.$refs.wordChart);
    }
    // 获取 chart 元素
    const chartDom = that.$refs.wordChart;
    // 初始化 echarts
    const myChart = echarts.init(chartDom);
    //let data = Object.entries(detail).map(([name, value]) => ({name, value}));//这个detail就是你自己通过handlp获取到的关键词存储到了数据库,通过后端数据库查询到的值传过来来的,我这里是传了一个map回来,关键词和值的key-value形式
    // 示例数据
    let data = [
      { value: 60, name: '运量' },
      { value: 41, name: '延安路' },
      { value: 37, name: '公交' },
      { value: 35, name: '中运量' },
      { value: 15, name: '申昆路' },
      { value: 14, name: '路' },
      { value: 13, name: '上海' },
      { value: 11, name: '车道' },
      { value: 10, name: '电车' },
      { value: 10, name: '终点站' },
      { value: 9, name: '公交车' },
      { value: 9, name: '专用道' },
      { value: 9, name: '载客' },
      { value: 8, name: '无轨电车' },
      { value: 7, name: '开通' },
      { value: 7, name: '外滩' },
      { value: 7, name: '专用' },
      { value: 5, name: '线路' },
      { value: 5, name: '全文' },
      { value: 5, name: '延安东路' },
      { value: 4, name: '延安西路' },
      { value: 4, name: '试运行' },
      { value: 3, name: 'brt' },
      { value: 3, name: '高架' },
      { value: 3, name: '司机' },
      { value: 3, name: '运营' },
      { value: 3, name: '枢纽站' },
      { value: 2, name: '联调' },
      { value: 2, name: '区间' },
      { value: 2, name: '巴士' },
      { value: 2, name: '巨龙' },
      { value: 2, name: '中山东一路' },
      { value: 2, name: '车辆' },
      { value: 2, name: '虹桥' },
      { value: 2, name: '青平公路' },
      { value: 2, name: '乘坐' },
      { value: 2, name: '巨龙车' },
      { value: 2, name: '乘客' },
      { value: 2, name: '线网' },
      { value: 2, name: '通车' },
      { value: 2, name: '车站' },
      { value: 2, name: '去外滩' },
      { value: 2, name: '空载' },
      { value: 2, name: '尝鲜' },
      { value: 2, name: '红灯' },
      { value: 2, name: '体验' },
      { value: 2, name: '安东路外滩' },
      { value: 2, name: '试车' },
      { value: 2, name: '速递' },
      { value: 2, name: '站台' },
      { value: 2, name: '延安' },
      { value: 1, name: '西藏' },
      { value: 1, name: '客流' },
      { value: 1, name: '车厢' },
      { value: 1, name: '上海·七莘' },
      { value: 1, name: '长宁' },
      { value: 1, name: '恶臭' },
      { value: 1, name: '娄山关' },
      { value: 1, name: '天桥' },
      { value: 1, name: '红绿灯' },
      { value: 1, name: '正式' },
      { value: 1, name: '路权' },
      { value: 1, name: '新片' },
      { value: 1, name: '视频' },
      { value: 1, name: '头班车' },
      { value: 1, name: '中路' },
      { value: 1, name: '北路站' },
      { value: 1, name: '传说' },
      { value: 1, name: '小时' },
      { value: 1, name: '路试' },
      { value: 1, name: '单程' },
      { value: 1, name: '路上' },
      { value: 1, name: '拥堵' },
      { value: 1, name: '启用' },
      { value: 1, name: '换乘' },
      { value: 1, name: '调试' },
      { value: 1, name: '中门' },
      { value: 1, name: '凯旋路' },
      { value: 1, name: '候车' },
      { value: 1, name: '双流路' },
      { value: 1, name: '上班' },
      { value: 1, name: '天山路' },
      { value: 1, name: '交通委' },
      { value: 1, name: '市民' },
      { value: 1, name: '发车' },
      { value: 1, name: '上车' },
      { value: 1, name: '开车' },
      { value: 1, name: '驾驶员' },
      { value: 1, name: '路线' },
      { value: 1, name: '样车' },
      { value: 1, name: '华山路' },
      { value: 1, name: '缩线' },
      { value: 1, name: '铰接' },
      { value: 1, name: '马路' },
      { value: 1, name: '凑热闹' },
      { value: 1, name: '高峰' },
      { value: 1, name: '中路站' },
      { value: 1, name: '你好' },
      { value: 1, name: '外滩站' }
    ]
    //因为这里我采用了自定义形状的方式,数据太少,展示不出具体的形状,所以我就把数据扩大了,大家可以结合自身业务情况选择用不用自定义形状
    data = [...data,...data,...data,...data]
 //词云图自定义形状   
const maskImage = new Image();
  //五角星形状 图片可以转Base64,也可以你引入到的项目中直接获取
maskImage.src=''
    //爱心形状 //maskImage.src=''

    // 配置项
    const option = {
      series: [{
        type: 'wordCloud',
        shape: 'roundRect',
        maskImage: maskImage,
        sizeRange: [10, 30],//设置关键词字体大小
        rotationRange: [0, 0],
        rotationStep: 45,
        gridSize: 10,//设置间隔距离
        drawOutOfBound: false,
        data: data,
        height:'100%',//这里你如果使用自定义的形状,必须保证你的高度足够和宽度足够
        width:'100%',
        textStyle: {
          color: function() {
            // Random color
            return 'rgb(' + [
              Math.round(Math.random() * 160),
              Math.round(Math.random() * 160),
              Math.round(Math.random() * 160)
            ].join(',') + ')'
          }
        },
        emphasis: {
          focus: 'self', // 设置词云图的 emphasis 样式
          textStyle: {
            shadowBlur: 10,
            shadowColor: '#333'
          },
        }
      }],
    };
    // 设置图表配置项
    maskImage.onload =function (){
      myChart.setOption(option);
    }
    myChart.on('click', function (params) {
      that.keyword = params.data.name
      that.doSearch()
    });
  }

注意事项:

1.要使用echats的词云图,需要先前端下载 echarts-wordcloud,下载方式 npm install echarts-wordcloud;

2.小伙伴如果要自己找另外的形状,可以去阿里巴巴矢量图标库里面找,直接下载为png的图片就好了,但是我建议最好不要用线性的图标,因为线性的图可能很难出现你需要的效果,就是页面上不报错,词云图就是一片白板,其实是出现了,但是跟图标形状有关,有的词直接就超出你的范围,就看不到了,我建议用填充(filling)的矢量图,图标库链接如下:

iconfont-阿里巴巴矢量图标库icon-default.png?t=N7T8https://www.iconfont.cn/search/index?searchType=icon&q=%E5%BF%83&page=1&fromCollection=-1&tag=fill

3. 图片下载好了之后,可以有两个选择

        1.图片转Base64,可以去这个转化网站,进行转化,链接如下:base64图片在线转换工具 - 站长工具 (chinaz.com)icon-default.png?t=N7T8https://tool.chinaz.com/tools/imgtobase/

然后复制转化出来的链接,maskImage.src='你转化出来的链接' 

       2.如果不想转Base64也是可以的,直接把图片放到你的项目的某个资源包下面,然后获取地址,比如 maskImage.src= require('./image/star.png'),最好用上require,不然有可能你是获取不到那个图片的。

 4.词云图里面的每个关键词是可以绑定点击事件的,我这里就绑定了一个事件,用来查询与关键词相关的数据,代码如下:

myChart.on('click', function (params) {
      that.keyword = params.data.name
      that.doSearch()
    });

    这里要注意的是你当前如果直接使用this的话,是调用不到你外面的其他方法的,你需要指定最开始的this,所以我在最上面定义了 const that = this,这样通过that.方法名()就可以调用啦。

总结:通过如上的操作就可以实现我们上面的效果啦,希望能帮到各位小伙伴!

  • 20
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Vue实现复杂自定义覆盖物可以使用百度地图API中提供的Overlay类和自定义覆盖物。自定义覆盖物是指在地图上添加自己的DOM元素,可以通过DOM元素来实现自己的样式和交互效果。 下面是在Vue实现复杂自定义覆盖物的步骤: 1. 安装vue-baidu-map 在终端中运行以下命令来安装vue-baidu-map: ``` npm install vue-baidu-map --save ``` 2. 注册vue-baidu-map组件 在Vue组件中注册vue-baidu-map组件: ``` import BaiduMap from 'vue-baidu-map' export default { components: { BaiduMap } } ``` 3. 在模板中添加地图 在模板中添加vue-baidu-map标签,并设置地图的中心点和缩放级别: ``` <template> <div> <BaiduMap :center="center" :zoom="zoom"></BaiduMap> </div> </template> <script> export default { data() { return { center: {lng: 116.404, lat: 39.915}, zoom: 15 } } } </script> ``` 4. 创建自定义覆盖物 在Vue组件的mounted()生命周期函数中,创建自定义覆盖物: ``` mounted() { const map = this.$refs.baiduMap.getBMap() const BMap = window.BMap const CustomOverlay = function(point, options) { this._point = point this._options = options } CustomOverlay.prototype = new BMap.Overlay() CustomOverlay.prototype.initialize = function(map) { this._map = map const div = document.createElement('div') div.style.position = 'absolute' div.style.width = '100px' div.style.height = '100px' div.style.background = '#fff' div.style.borderRadius = '50%' div.style.boxShadow = '0 0 15px rgba(0, 0, 0, 0.3)' div.style.cursor = 'pointer' div.innerHTML = '<span>自定义覆盖物</span>' div.addEventListener('click', () => { console.log('自定义覆盖物被点击了') }) map.getPanes().labelPane.appendChild(div) this._div = div return div } CustomOverlay.prototype.draw = function() { const pixel = this._map.pointToOverlayPixel(this._point) this._div.style.left = pixel.x - 50 + 'px' this._div.style.top = pixel.y - 50 + 'px' } const point = new BMap.Point(116.404, 39.915) const myOverlay = new CustomOverlay(point) map.addOverlay(myOverlay) } ``` 在上面的代码中,我们创建了一个CustomOverlay类,它继承了BMap.Overlay类,用于创建自定义覆盖物。在CustomOverlay类的initialize方法中,我们创建了一个DIV元素,并设置了DIV元素的样式和内容。我们将DIV元素添加到地图的labelPane层中,这样它就可以显示在其他标注之上了。在CustomOverlay类的draw方法中,我们将DIV元素的位置设置为自定义覆盖物的位置。 5. 添加CSS样式 最后,我们需要添加CSS样式来定义自定义覆盖物的样式: ``` <style> .custom-overlay { position: absolute; width: 100px; height: 100px; background: #fff; border-radius: 50%; box-shadow: 0 0 15px rgba(0, 0, 0, 0.3); cursor: pointer; } </style> ``` 在上面的代码中,我们定义了".custom-overlay"类来设置自定义覆盖物的样式。 这样就可以在Vue实现复杂自定义覆盖物了。可以根据需要修改CustomOverlay类的实现,来实现更复杂的自定义覆盖物。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值