CodeChops.Geometry 4.3.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package CodeChops.Geometry --version 4.3.0                
NuGet\Install-Package CodeChops.Geometry -Version 4.3.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="CodeChops.Geometry" Version="4.3.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add CodeChops.Geometry --version 4.3.0                
#r "nuget: CodeChops.Geometry, 4.3.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install CodeChops.Geometry as a Cake Addin
#addin nuget:?package=CodeChops.Geometry&version=4.3.0

// Install CodeChops.Geometry as a Cake Tool
#tool nuget:?package=CodeChops.Geometry&version=4.3.0                

Geometry

Objects and helpers to provide easy calculations of objects in 2D-space and time. These objects can be (de)serialized to/from JSON. This library extensively uses the new generic math functionality of .NET 7 so each object can contain the numeric types you prefer.

Check out CodeChops projects for more projects.

Space

Point

A 2-dimensional location value object with TNumber as type of the underlying values of X and Y. Contains:

  • Operators to perform calculations.
  • Default casts (also from/to ValueTuple).
  • Converters to convert to a different TNumber.
  • Some simple predefined calculations: Sum(), Multiply().

Line

A line holds two points: a starting point and end point. Contains:

  • Casts to and from Size.
  • Converters to convert to a different TNumber.
  • Some simple predefined calculations: Distance(), Difference().
  • An iterator to iterate all points in the line foreach(var point in new Line<int>((0,0), (10, 10))

Size

A 2-dimensional measurement value object with TNumber as type of the underlying values of Width and Height. Contains:

  • Operators to perform calculations.
  • Default casts (also from/to ValueTuple).
  • Converters to convert to a different TNumber.
  • Some simple predefined calculations: Circumference(), Area().
  • An iterator to iterate all points in the size: GetAllPoints() or use foreach(var point in new Size<int>(10, 10)).
  • Extension to convert size to inline css.

Surface

An Euclidean plane of a specific size (and offset). Contains bound checks using the size offset.

  • Some simple predefined calculations: Circumference, Area.
  • Converters to convert to a different TNumber.
  • A way to (try to) get the address of a point on the plan.
  • An iterator to iterate all points in a certain direction (in number of moments).
  • An iterator to iterate all points of a line.
  • An iterator to iterate all points in the dimensions.

Directions

A direction holds a point which contains the delta in X and Y. There are different types of directions. Every direction type is a value object (and therefore immutable).

FreeDirection

A direction in every possible delta point. Contains:

  • An Angle, which also can be consumed by the constructor of FreeDirection.
  • Default casts.
  • Converters to convert to a different TNumber.
  • Methods to take a (random) turn.

StrictDirection

A strongly typed direction that resides in a specific enum which holds other direction values. This object makes it easy to enumerate over the directions and search for them. No free directions can be used. Contains:

  • Predefined definitions:
    • DiagonalDirection
    • EveryDirection
    • HorizontalDirection
    • OrthogonalDirection
    • VerticalDirection
  • Default casts.
  • Converters to convert to a different TNumber.
  • Converters to (try to) convert to a different StrictDirection.
  • Methods to take a (random) turn using RotationType.

StrictDirections make use of the MagicEnums library to easily enumerate directions in one definition.

StrictDirections make use of the ImplementationDiscovery library to easily enumerate different definitions.

An example of predefined definition DiagonalDirection

public static readonly DiagonalDirection<TNumber> NorthEast = CreatePoint( 1, -1);
public static readonly DiagonalDirection<TNumber> SouthEast = CreatePoint( 1,  1);
public static readonly DiagonalDirection<TNumber> SouthWest = CreatePoint(-1,  1);
public static readonly DiagonalDirection<TNumber> NorthWest = CreatePoint(-1, -1);

NoDirection

A singleton object that holds a delta point of (0, 0).

Movements

Describes in what direction an object moves from a starting point, using a moment counter. There are different types of movements. Every movement type is a value object (and therefore immutable).

StraightMovement

A movement that only goes into one straight direction over its lifetime.

DynamicMovement

A movement in which the direction and (therefore the location over time) can be determined by using a formula.

NoMovement

Should be used for objects that don't move. It can still hold a direction.

MomentCounter

A moment counter helps calculating the direction and location of a moving object deterministically. The moments can be calculated over time using a TimedMomentCounter, or manual moments using ManualMomentCounter.)

TimedMomentCounter

A counter in which the moments are incremented over time, using a stopwatch. The timer can be stopped and (re)started. A momentsCountGetter can be provided in order to control what order of magnitude should be used (seconds, milliseconds, etc.).

ManualMomentCounter

A counter in which the moments are incremented manually until maximum moments.

MomentCounterScope

Controls access to a moment counter in the ambient context. This way a statically shared moment counter can be accessed and controlled from the outside.

This functionality makes use of Ambient Context pattern as implemented by TheArchitectDev. See Architect.AmbientContexts.

Time

IStopwatch

Wraps a Stopwatch in order to be able to control the stopwatch from the outside.

UnixEpochConverter

A small helper to convert DateTimes to Unix time stamps and vice versa.

Product Compatible and additional computed target framework versions.
.NET net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
4.10.1 100 11/19/2024
4.10.0 311 3/20/2023
4.9.0 348 1/27/2023
4.8.0 319 1/22/2023
4.6.1 361 1/21/2023
4.6.0 364 1/21/2023
4.5.2 361 1/20/2023
4.5.1 349 1/18/2023
4.5.0 329 1/18/2023
4.4.1 331 1/18/2023
4.4.0 339 1/18/2023
4.3.2 338 1/16/2023
4.3.1 347 1/15/2023
4.3.0 374 1/11/2023
4.2.0 349 1/10/2023
4.1.1 362 1/6/2023
4.0.0 571 1/3/2023
2.4.4 481 7/11/2022
2.4.3 439 7/10/2022
2.4.2 453 7/10/2022
2.4.1 470 7/10/2022
2.4.0 491 6/23/2022
2.3.8 472 6/23/2022
2.3.7 472 6/21/2022
2.3.6 461 6/12/2022
2.3.5 483 4/19/2022
2.3.4 456 4/19/2022
2.3.3 471 4/6/2022
2.3.2 498 4/6/2022
2.3.1 473 4/6/2022
2.2.2 488 3/23/2022
2.2.1 460 3/22/2022
2.2.0 470 3/22/2022
2.1.1 471 3/22/2022
2.1.0 484 3/17/2022
2.0.1 496 3/7/2022

Added surface iterator and moved surface classes.