104 lines
4.9 KiB
C#
104 lines
4.9 KiB
C#
/*
|
|
This file is part of the TSpdf (R) project.
|
|
Copyright (c) 1987-2023 TSpdf
|
|
Authors: TSpdf Software.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU Affero General Public License version 3
|
|
as published by the Free Software Foundation with the addition of the
|
|
following permission added to Section 15 as permitted in Section 7(a):
|
|
FOR ANY PART OF THE COVERED WORK IN WHICH THE COPYRIGHT IS OWNED BY
|
|
TSpdf GROUP. TSpdf GROUP DISCLAIMS THE WARRANTY OF NON INFRINGEMENT
|
|
OF THIRD PARTY RIGHTS
|
|
|
|
This program is distributed in the hope that it will be useful, but
|
|
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
or FITNESS FOR A PARTICULAR PURPOSE.
|
|
See the GNU Affero General Public License for more details.
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program; if not, see http://www.gnu.org/licenses or write to
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
Boston, MA, 02110-1301 USA, or download the license from the following URL:
|
|
http://TSpdfpdf.com/terms-of-use/
|
|
|
|
The interactive user interfaces in modified source and object code versions
|
|
of this program must display Appropriate Legal Notices, as required under
|
|
Section 5 of the GNU Affero General Public License.
|
|
|
|
In accordance with Section 7(b) of the GNU Affero General Public License,
|
|
a covered work must retain the producer line in every PDF that is created
|
|
or manipulated using TSpdf.
|
|
|
|
You can be released from the requirements of the license by purchasing
|
|
a commercial license. Buying such a license is mandatory as soon as you
|
|
develop commercial activities involving the TSpdf software without
|
|
disclosing the source code of your own applications.
|
|
These activities include: offering paid services to customers as an ASP,
|
|
serving PDFs on the fly in a web application, shipping TSpdf with a closed
|
|
source product.
|
|
|
|
For more information, please contact TSpdf Software Corp. at this
|
|
address: sales@TSpdfpdf.com
|
|
*/
|
|
using TSpdf.Test;
|
|
|
|
namespace TSpdf.Kernel.Geom {
|
|
[NUnit.Framework.Category("UnitTest")]
|
|
public class LineSegmentTest : ExtendedTSpdfTest {
|
|
[NUnit.Framework.Test]
|
|
public virtual void ContainsPointNullTest() {
|
|
LineSegment lineSegment = new LineSegment(new Vector(20.3246f, 769.4974f, 1.0f), new Vector(151.22923f, 769.4974f
|
|
, 1.0f));
|
|
NUnit.Framework.Assert.IsFalse(lineSegment.ContainsPoint(null));
|
|
}
|
|
|
|
[NUnit.Framework.Test]
|
|
public virtual void ContainsPointTest() {
|
|
Vector pointToCheck = new Vector(20.3246f, 769.4974f, 1.0f);
|
|
LineSegment lineSegment = new LineSegment(pointToCheck, new Vector(151.22923f, 769.4974f, 1.0f));
|
|
NUnit.Framework.Assert.IsTrue(lineSegment.ContainsPoint(pointToCheck));
|
|
}
|
|
|
|
[NUnit.Framework.Test]
|
|
public virtual void NotContainsPointLeftTest() {
|
|
Vector pointToCheck = new Vector(100.3246f, 769.4974f, 1.0f);
|
|
LineSegment lineSegment = new LineSegment(new Vector(120.3246f, 769.4974f, 1.0f), new Vector(151.22923f, 769.4974f
|
|
, 1.0f));
|
|
NUnit.Framework.Assert.IsFalse(lineSegment.ContainsPoint(pointToCheck));
|
|
}
|
|
|
|
[NUnit.Framework.Test]
|
|
public virtual void NotContainsPointRightTest() {
|
|
Vector pointToCheck = new Vector(160.3246f, 769.4974f, 1.0f);
|
|
LineSegment lineSegment = new LineSegment(new Vector(120.3246f, 769.4974f, 1.0f), new Vector(151.22923f, 769.4974f
|
|
, 1.0f));
|
|
NUnit.Framework.Assert.IsFalse(lineSegment.ContainsPoint(pointToCheck));
|
|
}
|
|
|
|
[NUnit.Framework.Test]
|
|
public virtual void ContainsSegmentNullTest() {
|
|
LineSegment lineSegment = new LineSegment(new Vector(100.3246f, 769.4974f, 1.0f), new Vector(151.22923f, 769.4974f
|
|
, 1.0f));
|
|
NUnit.Framework.Assert.IsFalse(lineSegment.ContainsSegment(null));
|
|
}
|
|
|
|
[NUnit.Framework.Test]
|
|
public virtual void ContainsSegmentTest() {
|
|
LineSegment lineSegment = new LineSegment(new Vector(100.3246f, 769.4974f, 1.0f), new Vector(151.22923f, 769.4974f
|
|
, 1.0f));
|
|
LineSegment segmentToCheck = new LineSegment(new Vector(110.3246f, 769.4974f, 1.0f), new Vector(140.22923f
|
|
, 769.4974f, 1.0f));
|
|
NUnit.Framework.Assert.IsTrue(lineSegment.ContainsSegment(segmentToCheck));
|
|
}
|
|
|
|
[NUnit.Framework.Test]
|
|
public virtual void NotContainsSegmentTest() {
|
|
LineSegment lineSegment = new LineSegment(new Vector(120.3246f, 769.4974f, 1.0f), new Vector(151.22923f, 769.4974f
|
|
, 1.0f));
|
|
LineSegment segmentToCheck = new LineSegment(new Vector(110.3246f, 769.4974f, 1.0f), new Vector(115.22923f
|
|
, 769.4974f, 1.0f));
|
|
NUnit.Framework.Assert.IsFalse(lineSegment.ContainsSegment(segmentToCheck));
|
|
}
|
|
}
|
|
}
|