Scope
The scope of this project is to document the coding of a rather complex problem.
Basic Code
To begin I need:
- a "segment" intersection routine
- an offset routine
- some test data
I have decided to truncate intersection "rays" in the basic code.
Note: a segment is line bounded by two points while a ray is an infinitely long line.
Resolving Cross-Overs
Resolving cross-overs can wait until the basic code works as well as it can.
Initial Experiments
Initially to test the two main routines I built a program that steps through increasing angles for two joined segments:
Here is the first case where the offset segments intersect:
data:image/s3,"s3://crabby-images/b07ff/b07ffd61a3bfb3374a257b876d41593f249da37b" alt=""
Here is the second case where the offset polylines intersect because I have extended the offset segments the offset distance:
data:image/s3,"s3://crabby-images/53d38/53d3881e89e75c5b382dfd9a7806b40de0685f4f" alt=""
Here is the third case where the intersection exceeds the extended offset segment. In this case I have truncated the offset polyline:
data:image/s3,"s3://crabby-images/80cc0/80cc0ea1039867a163909a2b6379e717f32a9d5d" alt=""
This truncated offset polyline is fine for CNC mill or laser cutting applications.
The last case is problematic:
data:image/s3,"s3://crabby-images/38378/383787cc34dca3fded94d005920b4fa5f46dfd08" alt=""
I have to either accept this or a ray intersection.
After a lot experimentation, I decided to accept the ray intersection.
A final case to consider is co-linear segments. The two spikes are co-linear segments:
data:image/s3,"s3://crabby-images/02be8/02be826f777ec717311463584c83878eaba99329" alt=""
Next Set of Experiments
Here is my test data (the white closed polyline) for the next set of experiments:
data:image/s3,"s3://crabby-images/d82fe/d82fe981441e1136082f5a92b3d763ad44efc66f" alt=""
For this experiment I filtered the original (i.e. the white polyine) for near co-linear segments and very short segments. Although the original polyline appears symmetrical, the location of the points are not.
Hers is the contraction case:
data:image/s3,"s3://crabby-images/21f87/21f874c6270ec49c18ca0411f117a97249ec6e53" alt=""
If I expand or contract the original polyline sufficiently problems appear:
data:image/s3,"s3://crabby-images/8d44d/8d44d9fe29860c5ca7a56b09bc277643711bf051" alt=""
Note the offset polyline cross-over.
And:
data:image/s3,"s3://crabby-images/63107/63107a5eef30a84b1ba62a334fd62cde23a0e53f" alt=""
In this case the offset polyline has reversed direction. The offset polyline is also distorted due to the order of the offset point intersection truncation.
Status
At this point of time I have basic working code. There is potential to improve the code by resolving cross-overs and taking another approach to ray truncation.
AlanX