var TextWidth = new function() {
var widthLib = new Hash();
var textSpan;
var self = this; |
源代码 |
说明 |
self.getWidth = function(string, fontName, fontSize) {
var lib = getSizeLib(fontName, fontSize);
var totalWidth = 0;
for(var i =0; i < string.length; i++) {
var c = string.charCodeAt(i);
if (c > 255) {
totalWidth += lib[256];
}else{
totalWidth += lib[c];
}
}
return totalWidth;
}
|
内部成员变量
widthLib是一个保存某个字体、字号的所有字符的宽度的hash表;
|
self.wrapText = function(string, fontName, fontSize, maxWidth) {
if (!string) {
return " ";
}
var origText = string.strip();
var lib = getSizeLib(fontName, fontSize);
var resultText = "";
var deltaW;
var totalW = 0;
for(var i =0; i < string.length; i++) {
var c = string.charCodeAt(i);
if (c > 255) {
deltaW = lib[256];
}else{
deltaW = lib[c];
}
if ((totalW + deltaW) > maxWidth)
{
resultText += "";
totalW = deltaW;
}else{
totalW += deltaW;
}
resultText += string.charAt(i);
}
return resultText;
}
|
计算字符串的长度。算法简单,就是把每个字符的宽度都加到一起就好了。
关键是getSizeLib(fontName, fontSize);这个函数,如果Hash表里没有这个字体字号的宽度数据,它会主动初始化相应的宽度数据
|
self.setSpan = function(obj) {
textSpan = obj;
textSpan.hide();
}
|
计算折行。这个也简单,先从Hash表里拿到宽度数据,然后逐个计算,宽度超了,就加个 进去 |
function getSizeLib(fontName, fontSize) {
if (!widthLib.get(getKey(fontName, fontSize))) {
initwidthLib(fontName, fontSize);
}
return widthLib.get(getKey(fontName, fontSize));
}
|
保存用于宽度计算的span元素 |
function initwidthLib(fontName, fontSize) {
var key = getKey(fontName, fontSize);
var sizeLib = new Array(257);
textSpan.show();
textSpan.style.fontFamily = fontName;
textSpan.style.fontSize = fontSize+"px";
textSpan.update("中中中中中中中中中中");
sizeLib[256] = textSpan.offsetWidth/10;
for(var i = 0; i<256; i++) {
textSpan.update("中" + String.fromCharCode(i)+"中");
sizeLib[i] = textSpan.offsetWidth-2*sizeLib[256];
}
textSpan.hide();
widthLib.set(key, sizeLib);
}
|
取得指定字体字号的宽度数据。没有的话,就初始化一份 |
function getKey(fontName, fontSize) {
return fontName+"@"+fontSize+"px";
}
} |
初始化 |
|
|
|
|
内部メンバー変数
widthLib は、特定のフォントとフォント サイズのすべての文字の幅を保存するハッシュ テーブルです。
|