2013-02-26 11 views
5

私はいくつかのSVG要素の周りに線を描き、その領域内のオブジェクトを選択するプロジェクトに取り組んでいます。SVG要素を自由に手描きで選択してください

ここに私が今いるスクリーンショットがあります。私は達成しようとしていることを完全に明確にするために、ペイントを使ってラインを追加しました。描かれた円の中に2つのrectを選択したいと思います。

  1. mousedownpath要素を作成し、mouseup
  2. は場合に、pathを閉じるまで、マウスの動きを記録:私は解かなければならないステップの数が表示さ

    Screenshot http://s23.postimage.org/y6t5t9be3/Screen_Shot_2013_02_26_at_15_31_26.png

    ユーザーが円を描いていない

  3. 円の中に完全にまたは部分的に含まれるsvg要素を見つける

どのようなアプローチがありますか、どのように進むべきかについてのアドバイスはありますか?

私はD3.jsを使用しています。このslide(Mike Bostock、D3の作成者)は面白そうかもしれません。

+0

はhttp://ie.microsoft.com/testdrive/Browser/LassoBirdsに似てね/Default.htmlだが、それはSVGではなくキャンバスだと思う。 –

答えて

3

私は、次のステップに行くだろう:フリーハンドフォームのAABBを取得

  1. を(または最小/最大ボックス)、
  2. AABBフリーフォーム1と重なり、中に保存し、すべての要素を見つけますフリーハンド形の凸包を取得リスト、
  3. 試験凸包内部リスト嘘の要素からそれぞれまたは頂点の一部
場合

すべての頂点を凸包の内部に置くようにテストする場合、要素がフリーハンドの図の中に完全に入っているのか、それとも重なっているのかを判断できます。

残念ながら、私はd3.jsに精通していませんが、凸包、aabbs、テストポイントをポリゴンの内側に配置する方法を提供していると思います。おそらくそれも、ステップ2

幸運にAABBの重複見つけるために、AABBのクエリを作成する機能を提供します...

+1

ええ、何かがうまくいくはずです。ここでの答えは役に立つと思います:http://stackoverflow.com/questions/10029139/how-to-determine-whether-a-polygon-is-inside-other-one –

+0

+1私を凸包。キューには仕事に関連しないウィキペディアトローリングの2時間... –

+0

ありがとう@philipp。私はaabbの概念に精通していないので、私はそれを調べます。それは良いアプローチのように思えます。 – swenedo