SVG путь к SVG полилинии - PullRequest
1 голос
/ 26 июля 2011

Мне нужно знать, можно ли преобразовать путь SVG в полилинию SVG.
Я нашел код JavaScript, который преобразует путь в многоугольник :

function pathToPolygon(path,samples){
  if (!samples) samples = 0;
  var doc = path.ownerDocument;
  var poly = doc.createElementNS('http://www.w3.org/2000/svg','polygon');

  // Put all path segments in a queue
  for (var segs=[],s=path.pathSegList,i=s.numberOfItems-1;i>=0;--i) segs[i] = s.getItem(i);
  var segments = segs.concat();

  var seg,lastSeg,points=[],x,y;
  var addSegmentPoint = function(s){
    if (s.pathSegType == SVGPathSeg.PATHSEG_CLOSEPATH){

    }else{
      if (s.pathSegType%2==1 && s.pathSegType>1){
        // All odd-numbered path types are relative, except PATHSEG_CLOSEPATH (1)
        x+=s.x; y+=s.y;
      }else{
        x=s.x; y=s.y;
      }
      var lastPoint = points[points.length-1];
      if (!lastPoint || x!=lastPoint[0] || y!=lastPoint[1]) points.push([x,y]);
    }
  };
  for (var d=0,len=path.getTotalLength(),step=len/samples;d<=len;d+=step){
    var seg = segments[path.getPathSegAtLength(d)];
    var pt = path.getPointAtLength(d);
    if (seg != lastSeg){
      lastSeg = seg;
      while (segs.length && segs[0]!=seg) addSegmentPoint( segs.shift() );
    }
    var lastPoint = points[points.length-1];
    if (!lastPoint || pt.x!=lastPoint[0] || pt.y!=lastPoint[1]) points.push([pt.x,pt.y]);
  }
  for (var i=0,len=segs.length;i<len;++i) addSegmentPoint(segs[i]);
  for (var i=0,len=points.length;i<len;++i) points[i] = points[i].join(',');
  poly.setAttribute('points',points.join(' '));
  return poly;
}

я новичок в js и не понимаю эту строку: var seg, lastSeg, points = [], x, y;

это работает хорошо, но рисует рамку вокруг линии пути.но я не хочу кадр, я хочу преобразовать путь в набор точек, полилинии.возможно ли это благодаря

1 Ответ

3 голосов
/ 02 января 2012

Полилиния - это незамкнутый многоугольник. Полилинии могут начинаться и заканчиваться в одной и той же точке, что делает их равными многоугольнику.

Хотя пути имеют списки точек, вы можете указать, связаны ли точки с прямыми линиями или различными другими кривыми.

Я немного озадачен вашим вопросом: «он работает хорошо, но рисует рамку вокруг линии пути. Но я не хочу рамки»

Я думаю, что проблема здесь в некоторых атрибутах стиля, а не в типе объекта.

...