/Lego-Mindstorms

.NET Standard library to connect to Mindstorms bricks

Primary LanguageC#Apache License 2.0Apache-2.0

Lego Mindstorms (.NET Standard)

This library is heavily based on @BrianPeek's excellent work https://github.com/BrianPeek/legoev3.

Rewrite of the Lego.Ev3 library to support .NET Core

Project Structure

Source code is in the /Lego.Mindstorms directory. A sample console project is in the /Lego.Mindstorms.Client directory.

Prerequisites

Quick start

  1. Clone this repository in an empty directory:

    git clone https://github.com/seesharprun/Lego-Mindstorms .
    
  2. Connect your brick to your computer using a USB cable. For the test client, connect a large or small motor to Port A.

  3. Use the .NET CLI to execute the test project:

    dotnet run --project Lego.Mindstorms.Client/Lego.Mindstorms.Client.csproj
    

Code Sample (C#)

using (var communication = new UsbCommunication())
using (var client = new Lego.Mindstorms.MindstormsClient<UsbCommunication>(communication))
{
    await client.ConnectAsync();

    await client.TurnMotorAtPowerForTimeAsync(OutputPort.A, 50, 3000u, false);

    await client.PlayToneAsync(50, 5000, 500);
}

Project Release

Version 1.x of the library has been released to NuGet. This is a 1-to-1 port of the BrianPeek/legoev3 project to .NET Standard with minimal code changes.

NuGet Package

https://www.nuget.org/packages/Lego.Mindstorms/

Goals

  • Change namespace from Lego.Ev3.Desktop to Lego.Mindstorms
    • Much of the code can work with previous generations of Mindstorm bricks
  • Update library to be easier to use for new developers
    • Implement IDisposable for Brick library
    • Use generics
  • Modernize documentation using GitHub Pages
  • Investigate brick support on linux/osx/etc.
  • Take feature requests for Version 3