gpt4 book ai didi

javascript - 如何根据 Raphael JS 矩形包含的文本行设置其宽度和高度?

转载 作者:行者123 更新时间:2023-11-28 20:42:23 24 4
gpt4 key购买 nike

我正在创建一个矩形元素,稍后我想将其用作 SVG 圆形元素上的工具提示。现在,我正在尝试考虑一些逻辑来设置矩形元素的高度和宽度,该元素应根据它包含的文本行而变化。我只是创建一个 Raphael 文本元素并将其翻译到矩形上,以便看起来矩形“确实”包含文本。 (这是因为我不应该使用任何第三方工具提示插件,我也不能使用 jQuery 创建和修改它。我也不能使用 gRaphael。我应该只使用 Raphael 矩形元素作为工具提示。)

这就是我正在做的 -

var tipText = "Asoo ok m ml palksksk feesf k\nWeek:X-VAL\nRank:Y-VAL";
//splitting tipText for "\n"
var tipText_seperate = tipText.split("\n");
var tipText_seperate_len = tipText_seperate.length;

var line_len = [];
for(var i=0;i<tipText_seperate_len;i++){
line_len[i] = tipText_seperate[i].length;
}

var a = Math.max.apply(Math, line_len);//getting the length of largest line

//setting the width and height of the rectangle
var box = {};
box.width = (a*5)+5;
box.height = tipText_seperate_len*25;

var c = {};
c.x = 10;
c.y = 10;
c.r = paper.rect(c.x,c.y,box.width,box.height,5).attr({fill:'#000000', opacity:0.7});
c.t = paper.text(c.x,c.y,tipText).attr({fill:'#FFFFFF'});
c.t.transform("t"+box.width/2+","+box.height/2);

现在,矩形的大小会针对某些文本行进行调整,而对于某些文本行则不会。在这种情况下,我必须更改 box.width 的值,这似乎不正确。有没有有效且逻辑正确的方法来实现这一目标?请帮忙...

最佳答案

技巧是创建文本元素并使用 getBBox 获取文本元素的边界框,它提供尺寸以及 x y 值。

这是一个示例和 demo .

// Create Raphael and circle set
var Paper = new Raphael('canvas', 300, 300),
circles = Paper.set();

// Add circles to canvas, setting the tooltip text as a
// data attribute
circles.push(
Paper.circle(100, 150, 25).data('tooltip', 'Here is some text'),
Paper.circle(200, 150, 25).data('tooltip', 'And here is \nsome longer text')
);

// Some base styles
circles.attr({
fill: 'red',
stroke: 0
});

// Positioning of the tooltip box
var margin = 10,
padding = 5;

// Hover functions
circles.hover(
// On hover, create and show tooltip
function() {
// If the tooltip already exists on the element, simply
// show it. If it doesn't then we need to create it.
if (this.tooltip && this.tooltip.box) {
this.tooltip.show();
this.tooltip.box.show();
} else {
// Get the x and y positions.
// We get the 'true y' by deducting the radius
var x = this.attr('cx'),
y = this.attr('cy') - this.attr('r');

// Create the tooltip text, attaching it to the
// circle itself
this.tooltip = Paper.text(x, y, this.data('tooltip'));

// Calculate the bounding box of our text element
var bounds = this.tooltip.getBBox();

// Shift the text element in to correct position
this.tooltip.attr({
// At this point `y` is equal to the top of the
// circle arc. When creating a text element, the
// `x` and `y` values are center points by default,
// so by deducting half the height we can fake
// a bottom align. Finally deducting our `margin`
// value creates the space between the circle and
// the tooltip.
y: y - (bounds.height / 2) - margin,
fill: '#fff'
});

// Create the tooltip box, again attaching it to the
// circle element.
//
// The `x`, `y` and dimensions are dynamically calculated
// using the text element's bounding box and margin/padding
// values.
//
// The `y` value again needs some special treatment,
// creating the fake bottom align by deducting half the
// text element's height. We then adjust the `y` further
// by deducting the sum of the `padding` and `margin`.
// The `margin` value is needed to create space between
// the circle and the tooltip, and the `padding` value
// shifts the box a little higher to create the illusion of
// padding.
//
// Try adjusting the `margin` and `padding` values.
this.tooltip.box = Paper.rect(bounds.x - padding, bounds.y - (bounds.height / 2) - (padding + margin), bounds.width + (padding * 2), bounds.height + (padding * 2));

// Style the box and put it behind text element
this.tooltip.box.attr({
fill: '#000',
stroke: 0
}).toBack();
}
},
// On hover out, hide previously created tooltip
function() {
// Hide the tooltip elements
this.tooltip.box.hide();
this.tooltip.hide();
}
);​

关于javascript - 如何根据 Raphael JS 矩形包含的文本行设置其宽度和高度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14133337/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com