antv g6 中shape为image时,怎么设置img属性为本地图片啊

JavaScript010

antv g6 中shape为image时,怎么设置img属性为本地图片啊,第1张

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title>词云</title>

<script src="https://a.alipayobjects.com/jquery/jquery/1.11.1/jquery.js"></script>

<script src="https://a.alipayobjects.com/g/datavis/g2/2.3.2/g2.js"></script>

</head>

<body>

<div id="c1"></div>

<script src="https://a.alipayobjects.com/g/datavis/g-cloud/1.0.2/index.js"></script>

<script>

var Util = G2.Util

var Shape = G2.Shape

function getTextAttrs(cfg) {

var textAttrs = Util.mix(true, {}, {

fillOpacity: cfg.opacity,

fontSize: cfg.size,

rotate: cfg.origin._origin.rotate,

text: cfg.origin._origin.text,

textAlign: 'center',

fill: cfg.color,

textBaseline:'Alphabetic'

}, cfg.style)

return textAttrs

}

// 给point注册一个词云的shape

Shape.registShape('point', 'cloud', {

drawShape: function(cfg, container) {

cfg.points = this.parsePoints(cfg.points)

var attrs = getTextAttrs(cfg)

// 给容器添加text类型的shape

// 坐标仍然是原来的坐标

// 文字样式为通过getTextAttrs方法获取的样式

var shape = container.addShape('text', {

attrs: Util.mix(attrs, {

x: cfg.points[0].x,

y: cfg.points[0].y

})

})

return shape

}

})

//json数据的地址:https://antv.alipay.com/static/data/g2pv.json

$.getJSON('./g2pv.json', function(data) {

data.sort(function(a,b){

return b.pv-a.pv

})

// 获取数据的最大值和最小值

var max = data[0].pv

var min = data[data.length-1].pv

// 构造一个词云布局对象

var imageCloud = new Cloud({

// 传入数据源

words: data,

// 设定宽高(默认为500*500)

width: 650,

height: 450,

// 设定文字大小配置函数(默认为12-40px的随机大小)

size: function(words){

// 将pv映射到canvas可绘制的size范围14-100(canvas默认最小文字为12px)

return ((words.pv - min)/(max - min)) * (100 - 14) + 14

},

// 设定文字内容

text: function(words){

// 将网址处理成用'.'分隔开的第一个字符串

var index = words.site.indexOf('.')

var text = words.site

if(index >0 &&index <words.site.length){

text = words.site.substr(0,index)

// 当字符串是'www'时获取下一个

if(text === 'www'){

text = words.site.substr(index + 1)

index = text.indexOf('.')

text = text.substr(0,index)

}

// 当字符串是数字时获取整个网址

if(/^[0-9]*$/g.test(text)) {

text = words.site

}

}

return text

}

})

//图片地址

imageCloud.image("https://ss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=1185508753,3294372198&fm=23&gp=0.jpg",function(Cloud){

Cloud.exec(function(texts){

var chart = new G2.Chart({

id : 'c1',

// canvas的宽高需要和布局宽高一致

width: 850,

height: 600,

plotCfg : {

margin : 0

}

})

chart.legend(false)

chart.source(texts)

chart.axis(false)

chart.tooltip({

title:false

})

// 将词云坐标系调整为G2的坐标系

chart.coord().reflect()

// 绘制点图,在x*y的坐标点绘制自定义的词云shape,颜色根据text字段进行映射,大小根据size字段的真实值进行映射,文字样式配置为词云布局返回的样式,tooltip显示site*pv两个字段的内容

chart.point().position('x*y').color('text').size('size',function(size){

return size

}).shape('cloud').style({

fontStyle: texts[0].style,

fontFamily: texts[0].font,

fontWeight: texts[0].weight

}).tooltip('site*pv')

chart.render()

})

})

})

</script>

</body>

</html>

---------------------

《皇室风波》百度网盘高清资源免费在线观看:

链接: https://pan.baidu.com/s/1ufP7965tuUvRuc0AxQW21A

?pwd=g2js 提取码: g2js

《皇室风波》

导演: 马尔克·杜甘

编剧: 尚塔尔·托马、马尔克·杜甘

主演: 朗贝尔·维尔森、安娜玛丽亚·沃特鲁梅、奥利维埃·古尔梅、凯瑟琳·蒙切特、卡西·莫泰·克莱恩、艾戈尔·范·德赛尔、朱莉安娜·勒普罗、格温德林·古弗内克、文森特·隆迪兹、安德烈亚·费雷奥尔、玛雅·珊萨

类型: 剧情、历史

制片国家/地区: 法国、比利时、英国

语言: 法语

上映日期: 2017-12-27(法国)

片长: 100分钟

又名: 王妃的交易、王室风波、The Exchange of Princesses、The Royal Exchange

1721年,法国摄政王为了维护与西班牙之间的和平,向西班牙国王提出让法国的王位继承人,11岁的路易十五,迎娶4岁的西班牙公主玛丽亚。摄政王还提议将他的女儿,12岁的德蒙邦西埃小姐,嫁给14岁的西班牙的阿斯图里王子。西班牙积极响应了这两桩婚事,并迅速组织了交换仪式。交换公主的仪式将在与两国接壤的河流中的一个小岛上盛大举行。一切就绪,就等待孩子们展现出最好的一面,但没有想到所有的计划都是徒劳的。