Java-Gaming.org Hi !
 Featured games (83) games approved by the League of Dukes Games in Showcase (581) Games in Android Showcase (163) games submitted by our members Games in WIP (632) games currently in development
 News: Read the Java Gaming Resources, or peek at the official Java tutorials
Pages: [1]
 ignore  |  Print
 intersection line of 3d polygons  (Read 1209 times) 0 Members and 1 Guest are viewing this topic.
deepthought
 « Posted 2012-11-07 18:30:35 »

I need to be able to find the intersection line between a 3d triangle and a 3d quad. they will both always be coplanar (their points, not to each other).

right now the only thing i can think of is to:

1. get the planes of both polygons, then get the intersection line between them

2. for each side of both polygons: get a plane perpendicular to the ploygon's plane that lies along the side. clip the intersection line to each plane.

this seems rather inefficient to me, and i was wondering if anyone could suggest a better way.

jocks rule the highschools. GEEKS RULE THE WORLD MWAHAHAHA!!
captain failure test game
pjt33

« JGO Spiffy Duke »

Medals: 40
Projects: 4
Exp: 7 years

 « Reply #1 - Posted 2012-11-07 20:32:55 »

Find a normal N to the quad (as robustly as possible!)

Pick a point P in the quad. In the interests of robustness, my intuition says that you want the corner nearest the centroid of the triangle.

For each vertex V_i of the triangle, compute d_i = (V_i - P) . N.

If all three vertices have the same sign dot product, there is no intersection. Otherwise they will split 1-2. [1]  Wlog say that V_0 is positive and V_1 and V_2 are negative.

The intersection between the triangle and the plane of the quad runs from (d_0 V_1 - d_1 V_0) / (d_0 - d_1) to (d_0 V_2 + d_2 V_0) / (d_0 - d_2). Then clip that against the quad.

[1] Ignoring the special case where one of them is 0.
Pages: [1]
 ignore  |  Print

You cannot reply to this message, because it is very, very old.

 CopyableCougar4 (15 views) 2015-05-27 19:24:50 MrMapcom (24 views) 2015-05-23 20:26:16 MrMapcom (32 views) 2015-05-23 20:23:34 Waterwolf (37 views) 2015-05-20 15:01:45 chrislo27 (44 views) 2015-05-20 03:42:21 BurntPizza (79 views) 2015-05-10 15:53:18 FrozenShade (63 views) 2015-05-07 09:11:21 TheLopais (226 views) 2015-05-06 13:36:48 TheLopais (208 views) 2015-05-06 13:35:14 TheLopais (213 views) 2015-05-06 13:33:39
 Spasi 30x Rayvolution 23x Riven 16x Drenius 15x BurntPizza 15x theagentd 15x ra4king 13x opiop65 12x DavidBVal 11x Husk 11x EgonOlsen 11x princec 11x KevinWorkman 10x orangepascal 8x SauronWatchesYou 8x scanevaro 8x
 List of Learning Resources2015-05-05 10:20:32How to: JGO Wikiby Mac702015-02-17 20:56:162D Dynamic Lighting2015-01-01 20:25:42How do I start Java Game Development?by gouessej2014-12-27 19:41:21Resources for WIP gamesby kpars2014-12-18 10:26:14Understanding relations between setOrigin, setScale and setPosition in libGdx2014-10-09 22:35:00Definite guide to supporting multiple device resolutions on Android (2014)2014-10-02 22:36:02List of Learning Resources2014-08-16 10:40:00
 java-gaming.org is not responsible for the content posted by its members, including references to external websites, and other references that may or may not have a relation with our primarily gaming and game production oriented community. inquiries and complaints can be sent via email to the info‑account of the company managing the website of java‑gaming.org