1

私は、SVG 用のグラフィック エディターを開発しており、ユーザーが Web ブラウザーからアクセスできるようにオンラインに配置しています。SVG 編集に基づいており、Javascript で記述されています。

現時点では、アプリケーションには「ブール演算」と呼ばれるものがありません。これは、ユーザーが 2 つ以上の形状を選択してそれらを結合する機能です。

LIB2GEOM と呼ばれる C++ ライブラリを見つけました。これらの操作を処理するはずです。これは Inkscape も使用していると思います。

Javascriptで書かれていないので、このライブラリを私のアプリケーションとリンクする可能性はありますか?

         <div id="svgcontainer"></div>
    <script>

    function path2poly() 




 {
  var subj_polygons = [[{X:10,Y:10},{X:110,Y:10},{X:110,Y:110},{X:10,Y:110}],
                  [{X:20,Y:20},{X:20,Y:100},{X:100,Y:100},{X:100,Y:20}]]; 
  var clip_polygons = [[{X:50,Y:50},{X:150,Y:50},{X:150,Y:150},{X:50,Y:150}],
                  [{X:60,Y:60},{X:60,Y:140},{X:140,Y:140},{X:140,Y:60}]];
  var scale = 100;
subj_polygons = scaleup(subj_polygons, scale);
 clip_polygons = scaleup(clip_polygons, scale);
var cpr = new ClipperLib.Clipper();
cpr.AddPolygons(subj_polygons, ClipperLib.PolyType.ptSubject);
cpr.AddPolygons(clip_polygons, ClipperLib.PolyType.ptClip);
var subject_fillType = ClipperLib.PolyFillType.pftNonZero;
var clip_fillType = ClipperLib.PolyFillType.pftNonZero;
var clipTypes = [ClipperLib.ClipType.ctUnion];
var clipTypesTexts = "Union";
var solution_polygons, svg, cont = document.getElementById('svgcontainer');
var i;
for(i = 0; i < clipTypes.length; i++) {
solution_polygons = new ClipperLib.Polygons();
cpr.Execute(clipTypes[i], solution_polygons, subject_fillType, clip_fillType);
//console.log(JSON.stringify(solution_polygons));


 alert(polys2path(solution_polygons, scale));
 }

 }

// helper function to scale up polygon coordinates
function scaleup(poly, scale) {
 var i, j;
if (!scale) scale = 1;
for(i = 0; i < poly.length; i++) {
for(j = 0; j < poly[i].length; j++) {
  poly[i][j].X *= scale;
  poly[i][j].Y *= scale;
 }
}
return poly;
}

// converts polygons to SVG path string
function polys2path (poly, scale) {
var path = "", i, j;
if (!scale) scale = 1;
for(i = 0; i < poly.length; i++) {
for(j = 0; j < poly[i].length; j++) {
  if (!j) path += "M";
  else path += "L";
  path += (poly[i][j].X / scale) + ", " + (poly[i][j].Y / scale);
 }
 path += "Z";
 }
 return path;

}
 </script>
4

1 に答える 1

1

emscriptenを使用して JS にクロスコンパイルしてみることができます

于 2013-03-28T05:57:53.520 に答える