我是rapheal js的新手,我只需要使用paper.path()对象创建一个动态椭圆。

尽管我们可以使用paper.ellipse()来做到这一点,但是我需要仅根据预先存在的代码以路径方式完成它。我用谷歌搜索,只得到circle2path()的解决方案。

让我举一个例子来描述。

var paper = Raphael(10,10, 250, 250);
var start_x = 170;//this has to be dynamic
var start_y = 160;// so these are also
var r_x = 40;
var r_y = 35;
var ellipse = paper.ellipse(start_x,start_y,r_x,r_y);
// here instead of paper.ellipse, I need to use paper.path()
//for example I used path to create circle
var radius = 50;
var circle_path = "M"+ (start_x)+ (start_y-radius)+"A"+ radius+radius+0+1+1+(start_x-0.1)+(start_y-radius)+ "z";
var circle = paper.path(circle_path);


其正常工作的圈子。有什么办法与椭圆有关。

提前致谢。

最佳答案

尤里卡.........

我从this question获得了解决方案。

var paper = Raphael(10,10, 250, 250);
var start_x = 170;//this has to be dynamic
var start_y = 160;// so these are also
var r_x = 40;
var r_y = 35;
var ellipse = [["M", (start_x - r_x), (start_y)], ["a", r_x, r_y ,0, 1,1, 0,0.1 ],"z"];
var draw = paper.path(ellipse);


这就是我想要的。因此,我们可以为其创建一个函数。

var ellipse2path = function(start_x,start_y,r_x,r_y){
  return [["M", (start_x - r_x), (start_y)], ["a", r_x, r_y ,0, 1,1, 0,0.1 ],"z"];
};

07-24 17:51