繁体   English   中英

如何在raphael.js中使用paper.path对象创建动态椭圆

[英]How to create a dynamic ellipse using paper.path object in raphael.js

我是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);

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

提前致谢。

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

我从这个问题中得到了解决方案。

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"];
};

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM