亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

D3.js封裝文本實現自動換行和旋轉平移等功能

2019-11-20 08:45:18
字體:
來源:轉載
供稿:網友

我們下面話不多說,本文主要介紹的是利用D3.js封裝文本實現自動換行功能的步驟,下面來一起看看吧。

一、引用 multext.js 文件

multext.js

function appendMultiText(container, str, posX, posY, width, fontsize, fontfamily){						if( arguments.length < 6){				fontsize = 14;			}								if( arguments.length < 7){				fontfamily = "simsun, arial";			}						//獲取分割后的字符串			var strs = splitByLine(str,width,fontsize);						var mulText = container.append("text")				.attr("x",posX)				.attr("y",posY)				.style("font-size",fontsize)				.style("font-family",fontfamily);							mulText.selectAll("tspan")				.data(strs)				.enter()				.append("tspan")				.attr("x",mulText.attr("x"))				.attr("dy","1em")				.text(function(d){					return d;				});							return mulText;						function splitByLine(str,max,fontsize){				var curLen = 0;				var result = [];				var start = 0, end = 0;				for(var i=0;i<str.length;i++){					var code = str.charCodeAt(i);					var pixelLen = code > 255 ? fontsize : fontsize/2;					curLen += pixelLen;					if(curLen > max){						end = i;						result.push(str.substring(start,end));						start = i;						curLen = pixelLen;					}					if( i === str.length - 1 ){						end = i;						result.push(str.substring(start,end+1));					}				}				return result;			}}

可以另存為后,在 <script> 標簽里引用:

<script src="multext.js" charset="utf-8"></script> 

當然,要使用此文件,同時要引用 d3 的庫:

<script src="http://d3js.org/d3.v3.min.js" charset="utf-8"></script> 

二、函數的參數

文件里只實現了一個函數 appendMultiText() ,其各參數的意義為:

appendMultiText(   container,     //文本的容器,可以是<svg>或<g>    str,        //字符串   posX,        //文本的x坐標   posY,        //文本的y坐標   width,       //每一行的寬度,單位為像素   fontsize,      //文字的大?。墒÷裕J為 14   fontfamily     //文字的字體(可省略),默認為 simsun, arial ) 

三、添加多行文本

下面添加多行文本試試。首先要添加<svg>元素:

var width = 300; var height = 300;  var svg = d3.select("body")       .append("svg")       .attr("width",width)       .attr("height",height); 

添加的<svg>元素,保存在變量 svg 中,這個變量要作為 appendMultiText 的參數使用。

接下來添加多行文本:

var str = "青青子衿,悠悠我心,但為君故,沉吟至今。";                    appendMultiText(svg,str,30,100,120,20,"simsun"); 

代碼的意思為:在 svg 容器里的坐標(30, 100)處添加指定字符串,每一行的長度為120個像素,超出的部分自動換行,字體大小為20,字體為宋體。

結果如下:

可以看到,添加了四行文字,每行的長度為120個像素。appendMultiText自動為我們添加了<text ><tspan> 。
appendMultiText()的返回值是被添加的<text>元素的選擇集,可以用一個變量保存此值,再做旋轉平移之類的操作,當然也可更改字體等,例如:

var str = "青青子衿,悠悠我心,但為君故,沉吟至今。";                    var multext = appendMultiText(svg,str,30,100,120,20,"simsun");          multext.attr("transform","rotate(-20)"); 

文本逆時針旋轉20度。

你還可以將文本放到<g>元素里。

var g = svg.append("g");              var multext = appendMultiText(g,str,30,100,120); 

如此,多行文本的所有元素會置于<g>之下。上面這段代碼的 appendMultiText() 省略了最后兩個參數,如果省略,默認字體大小為 14px ,字體為 simsun, arial。

總結

以上就是利用D3.js封裝文本實現自動換行功能的全部內容,希望這篇文章的內容對大家學習或者使用D3.js能有所幫助,如果有疑問大家可以留言交流。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国内精品小视频在线观看| 欧美成人免费一级人片100| 久青草国产97香蕉在线视频| 97成人精品视频在线观看| 日日摸夜夜添一区| 尤物精品国产第一福利三区| 91久久在线观看| 成人日韩av在线| 亚洲国内精品在线| 成人网在线观看| 亚洲石原莉奈一区二区在线观看| 亚洲免费电影在线观看| 欧美电影免费播放| 亚洲电影免费观看高清完整版| 91精品国产乱码久久久久久久久| 久久久久久久久网站| 日韩欧美视频一区二区三区| 欧美午夜片在线免费观看| 精品久久久av| 国产综合久久久久久| 欧美日韩午夜视频在线观看| 国产一区二区日韩精品欧美精品| 91情侣偷在线精品国产| 欧美激情2020午夜免费观看| 欧美黄色性视频| 国产精品羞羞答答| 国产日韩在线亚洲字幕中文| 欧美激情网友自拍| 最近2019中文字幕第三页视频| 欧美高清视频在线播放| 国产精品专区一| 久久亚洲春色中文字幕| 欧美久久精品午夜青青大伊人| 亚洲精品免费网站| 欧美日韩国产成人在线观看| 亚洲人成电影网站色…| 国产精品久久99久久| 欧洲成人在线观看| 欧日韩不卡在线视频| 91人人爽人人爽人人精88v| 国产日韩欧美在线观看| 亚洲欧美在线一区| 国产精品欧美日韩| 欧美又大粗又爽又黄大片视频| 亚洲色图17p| 成人黄色网免费| 国产日韩视频在线观看| 91免费看片在线| 亚洲最大的av网站| 欧美日韩一区二区免费在线观看| 久久久av一区| 国产亚洲视频在线观看| 国产精品美女呻吟| 亚洲第一精品电影| 在线观看免费高清视频97| 国产欧美久久一区二区| 中文字幕亚洲情99在线| 久久精品国产成人| 中国人与牲禽动交精品| 亚洲福利视频久久| 久久久www成人免费精品| 欧美精品免费在线观看| 久久久久久亚洲| 国内精品久久久久| 欧美性猛交xxxx乱大交3| 日韩美女视频在线观看| 精品久久久久久中文字幕大豆网| 国产z一区二区三区| 亚洲成人激情小说| 俺去亚洲欧洲欧美日韩| 日韩暖暖在线视频| 午夜精品久久久久久久久久久久久| 日韩成人中文字幕在线观看| 亚洲免费av片| 亚洲精品女av网站| 欧美成人午夜剧场免费观看| 久久99精品久久久久久琪琪| 久久天堂电影网| 日韩在线视频观看| 久久视频在线直播| 91久久久久久久久久| 久久精品久久久久| 亚洲成年人影院在线| 亚洲国产小视频在线观看| 亚洲成av人乱码色午夜| 亚洲人成亚洲人成在线观看| 国产一区二区三区视频免费| 美女撒尿一区二区三区| 国产精品视频一区二区三区四| 一区二区三区美女xx视频| 日韩精品视频免费专区在线播放| 国产精品久久在线观看| 国产日韩在线一区| 68精品国产免费久久久久久婷婷| 亚洲一二三在线| 久久久精品久久久久| 欧美国产日韩二区| 日韩电影中文字幕| 欧美激情图片区| 色综合久久88色综合天天看泰| 一本色道久久综合狠狠躁篇的优点| 久久久在线观看| 欧美精品日韩三级| 日韩精品在线视频观看| 久久在线免费观看视频| 亚洲综合自拍一区| 成人黄色免费看| 97成人精品区在线播放| 91在线观看免费网站| 久久综合伊人77777蜜臀| 久久久国产精品视频| 欧美一区二区三区图| 久热爱精品视频线路一| 97成人精品区在线播放| 2019中文字幕在线免费观看| 精品国产欧美一区二区五十路| 欧美成人午夜激情| 中文字幕成人在线| 九九热最新视频//这里只有精品| 亚洲综合色av| 亚洲男人天堂古典| 国产精品精品视频一区二区三区| 91美女片黄在线观看游戏| 欧美色视频日本高清在线观看| 91精品国产综合久久香蕉的用户体验| 国产精品av电影| 国产视频自拍一区| www.日韩免费| 91精品视频专区| 欧美一级大片在线免费观看| 青青精品视频播放| 亚洲成av人片在线观看香蕉| 久久免费在线观看| 97人人爽人人喊人人模波多| 国产精品视频在线观看| 91九色单男在线观看| 欧美黑人xxxⅹ高潮交| 欧美高清一级大片| 欧美限制级电影在线观看| 91精品国产成人| 日韩精品视频观看| 伊人久久久久久久久久久| 中文在线资源观看视频网站免费不卡| 日韩**中文字幕毛片| 美日韩精品视频免费看| 国产精品扒开腿做爽爽爽的视频| 91美女片黄在线观| 欧美激情第99页| 国产欧美日韩免费看aⅴ视频| 97热精品视频官网| 中文字幕亚洲欧美一区二区三区| 日韩最新中文字幕电影免费看| 欧美综合在线观看| 狠狠做深爱婷婷久久综合一区| 欧美精品免费在线| 欧美成人精品h版在线观看| 国产精品嫩草视频| 97av在线视频| 亚洲第一偷拍网| 国产欧美一区二区三区在线看| 国产精品大陆在线观看| 日韩免费av片在线观看| 欧美日韩一区二区免费在线观看| 久久久亚洲成人|