gpt4 book ai didi

jquery - Raphael JS 的径向饼图菜单

转载 作者:太空狗 更新时间:2023-10-29 14:53:51 25 4
gpt4 key购买 nike

感谢您关注我的困境。我正在尝试用 raphael 制作一个 SVG 菜单,但我对几何很糟糕。

下图显示了我正在制作的东西。我已经用 CSS 创建了蓝色/中心部分,但似乎真的没有其他好的方法来获得白色/外部部分。由于这些元素的 block 性质,图像和 CSS 在这方面有点失败。我想生成一系列弧,其大小可根据元素的数量变化。

Radial Menu Example

那么,关于如何获得一系列形成四分之一圆并具有悬停效果的可点击弧线,有什么建议吗?如果重要的话,我也想在这些东西上放置图标。

我在 raphael 中看到了几个使用饼图的例子,但我不知道如何适应它。啊。我应该注意几何学。

感谢您的宝贵时间。

最佳答案

几何形状并没有那么糟糕,至少它不像elliptical arc path syntax in SVG那么烦人。 .两者都是可控的。

这是一个函数,它将生成一系列弧段作为路径,将每个弧段(连同该元素的任意元数据)传递给回调函数:

function generateRadialNav( paper,        // Raphael's paper object
cx, cy, // x and y coordinates of the center of the circle from which the arcs will be calculated
inner_radius, // pixels from origin to interior arc
radial_thickness, // width of navigation area in pixels
menu_items, // an object with one key per menu item; the value of each key is arbitrary
callback, // a finalization callback for menu items which should accept three arguments: the menu_items key, the path element, and the menu_items value. The first and third parameters are taken directly from the menu_items object.
options ) // Unused but added out of habit.
{
options = options || {};

var start_radians = options.start_radians || 0;
var end_radians = options.end_radians || Math.PI / 2;
var menu_item_count = 0;
for ( var k in menu_items )
menu_item_count++;

var slice_radians = ( end_radians - start_radians ) / menu_item_count;

var index = 0;
for ( var k in menu_items )
{
var path = [];
path.push( "M", cx + Math.cos( start_radians + slice_radians * index ) * inner_radius, cy + Math.sin( start_radians + slice_radians * index ) * inner_radius );
path.push( "L", cx + Math.cos( start_radians + slice_radians * index ) * ( inner_radius + radial_thickness ), cy + Math.sin( start_radians + slice_radians * index ) * ( inner_radius + radial_thickness ) );
path.push( "A",
inner_radius + radial_thickness, inner_radius + radial_thickness,
slice_radians, 0, 1,
cx + Math.cos( start_radians + slice_radians * ( index + 1 ) ) * ( inner_radius + radial_thickness ), cy + Math.sin( start_radians + slice_radians * ( index + 1 ) ) * ( inner_radius + radial_thickness ) );
path.push( "L", cx + Math.cos( start_radians + slice_radians * ( index + 1 ) ) * inner_radius, cy + Math.sin( start_radians + slice_radians * ( index + 1 ) ) * inner_radius );
path.push( "A",
inner_radius, inner_radius,
slice_radians, 0, 0,
cx + Math.cos( start_radians + slice_radians * index ) * inner_radius, cy + Math.sin( start_radians + slice_radians * index ) * inner_radius );
path.push( "Z" );

var element = paper.path( path ).attr( { fill: 'none', stroke: 'none' } );
callback( k, element, menu_items[k] );

index++;
}
}

此函数实质上将计算每个导航项的区域,生成具有该形状的路径,然后将菜单定义传递给回调。任何对图标的支持都必须单独添加,但我建议可以轻松扩充 menu_items 定义中的数据以支持它。有关使用此方法的示例,请查看 my test page -- 当然,请原谅匆忙的粗糙边缘!

关于jquery - Raphael JS 的径向饼图菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12429990/

25 4 0