首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >拉斐尔JS径向馅饼菜单

拉斐尔JS径向馅饼菜单
EN

Stack Overflow用户
提问于 2012-09-15 02:26:01
回答 1查看 9.2K关注 0票数 6

感谢你关注我的困境。我正试着和拉斐尔一起做一个SVG菜单,我的几何学很糟糕。

下图显示了我正在制作的内容。我已经用CSS创建了蓝色/中间部分,但似乎真的没有其他好方法来获得白色/外部部分。图像& CSS在这方面失败了,因为这些元素的块性。我想生成一系列的弧线,这些弧线的大小可以根据元素的数量而变化。

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

我见过一些在raphael中使用饼图的例子,但我就是不明白如何对其进行调整。呃。我应该注意几何学的。

耽误您时间,实在对不起。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-09-18 01:38:23

几何图形并不是真的那么糟糕,至少它不像elliptical arc path syntax in SVG那么烦人。两者都是可管理的。

下面是一个函数,它将生成一系列弧段作为路径,将每个弧段(以及该项目的任意元数据)传递给回调函数:

代码语言:javascript
复制
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 --当然,请原谅匆忙中的粗糙边缘!

票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12429990

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档