Implemented ContainsPoint function.
This commit is contained in:
parent
3259b8ba8d
commit
a3cf74a971
2 changed files with 14 additions and 4 deletions
|
@ -33,6 +33,7 @@ func main() {
|
||||||
gx.Point{1, 0},
|
gx.Point{1, 0},
|
||||||
}.Line()
|
}.Line()
|
||||||
fmt.Println(l1.Crosses(l2))
|
fmt.Println(l1.Crosses(l2))
|
||||||
|
fmt.Println(l1.ContainsPoint(gx.Point{1, 4}))
|
||||||
/*t := gx.Triangle{
|
/*t := gx.Triangle{
|
||||||
gx.Point{0, 0},
|
gx.Point{0, 0},
|
||||||
gx.Point{0, 100},
|
gx.Point{0, 100},
|
||||||
|
|
|
@ -31,12 +31,17 @@ func (l Line) Line() Line {
|
||||||
return l
|
return l
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l Line) Crosses(with Liner) (Point, bool) {
|
func (l Line) ContainsPoint(p Point) bool {
|
||||||
// Parallel liners cannot cross by definition.
|
buf := Line{0, p.Y}
|
||||||
if l.Parallel(with) {
|
pc, ok := l.crossesLine(buf)
|
||||||
return Point{}, false
|
if !ok {
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return pc == p
|
||||||
|
}
|
||||||
|
|
||||||
|
func (l Line) Crosses(with Liner) (Point, bool) {
|
||||||
switch with.(type) {
|
switch with.(type) {
|
||||||
case Line :
|
case Line :
|
||||||
return l.crossesLine(with.(Line))
|
return l.crossesLine(with.(Line))
|
||||||
|
@ -48,6 +53,10 @@ func (l Line) Crosses(with Liner) (Point, bool) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l1 Line) crossesLine(l2 Line) (Point, bool) {
|
func (l1 Line) crossesLine(l2 Line) (Point, bool) {
|
||||||
|
if l1.Parallel(l2) {
|
||||||
|
return Point{}, false
|
||||||
|
}
|
||||||
|
|
||||||
x := (l1.C - l2.C) / (l2.K - l1.K)
|
x := (l1.C - l2.C) / (l2.K - l1.K)
|
||||||
y := l1.K*x + l1.C
|
y := l1.K*x + l1.C
|
||||||
return Point{x, y}, true
|
return Point{x, y}, true
|
||||||
|
|
Loading…
Reference in a new issue