Remarks

Ssd1608
Status Status badge: working
Source code GitHub
Datasheet(s) GitHub
NuGet package NuGet Gallery for Meadow.Foundation.Displays.ePaper

The SSD1608 is a two-color display controller for ePaper displays. Data is sent to the controller via SPI and supports full screen updates only.

The SSD1608 is paired with a wide range of two color ePaper display sizes and resolutions.

Sample projects available on GitHub

Code Example

MicroGraphics graphics;

public override Task Initialize()
{
    Resolver.Log.Info("Initialize...");

    var display = new Ssd1608(spiBus: Device.CreateSpiBus(),
        chipSelectPin: Device.Pins.D02,
        dcPin: Device.Pins.D01,
        resetPin: Device.Pins.D00,
        busyPin: Device.Pins.D03,
        width: 200,
        height: 200);

    graphics = new MicroGraphics(display);

    return Task.CompletedTask;
}

public override Task Run()
{
    graphics.DrawRectangle(1, 1, 126, 32, Meadow.Foundation.Color.Black);

    graphics.CurrentFont = new Font8x12();
    graphics.DrawText(2, 2, "SSD1608", Meadow.Foundation.Color.Black);
    graphics.DrawText(2, 20, "Meadow F7", Meadow.Foundation.Color.Black);

    graphics.Show();

    return Task.CompletedTask;
}

Sample project(s) available on GitHub

Wiring Example

To control a SSD1608 from Meadow, connect the following:

SSD1608 Meadow Pin
BUSY D15
RST D14
DC D13
CS D12
CLK SCK
DIN MOSI
GND GND
3V3 3V3

If your display does not include any of the above pins, they can be omitted. Pass NULL into the constructor for the missing pin(s).

Wiring a SSD1608 to a Meadow F7

Characteristic Locus
Inheritance object EPaperBase EPaperMonoBase > Ssd1608 > Epd1in54 > Epd2in9
Implements ISpiPeripheral IDisposable IGraphicsDisplay
Inherited Members EPaperMonoBase.ColorMode EPaperMonoBase.SupportedColorModes EPaperMonoBase.PixelBuffer EPaperMonoBase.EnabledColor EPaperMonoBase.DisabledColor EPaperMonoBase.imageBuffer EPaperMonoBase.Width EPaperMonoBase.Height EPaperMonoBase.Clear(bool) EPaperMonoBase.Fill(Color, bool) EPaperMonoBase.Fill(int, int, int, int, Color) EPaperMonoBase.Clear(bool, bool) EPaperMonoBase.DrawPixel(int, int, bool) EPaperMonoBase.DrawPixel(int, int, Color) EPaperMonoBase.InvertPixel(int, int) EPaperMonoBase.Show(int, int, int, int) EPaperMonoBase.Show() EPaperMonoBase.WriteBuffer(int, int, IPixelBuffer) EPaperMonoBase.SetFrameMemory(byte[], int, int, int, int) EPaperMonoBase.SetFrameMemory(byte[]) EPaperMonoBase.DisplayFrame() EPaperMonoBase.Sleep() EPaperMonoBase.SendCommand(EPaperMonoBase.Command) EPaperBase.DefaultSpiBusSpeed EPaperBase.SpiBusSpeed EPaperBase.DefaultSpiBusMode EPaperBase.SpiBusMode EPaperBase.IsDisposed EPaperBase.commandBuffer EPaperBase.dataCommandPort EPaperBase.resetPort EPaperBase.chipSelectPort EPaperBase.busyPort EPaperBase.spiComms EPaperBase.DataState EPaperBase.CommandState EPaperBase.createdPorts EPaperBase.Write(byte) EPaperBase.Reset() EPaperBase.DelayMs(int) EPaperBase.SendCommand(byte) EPaperBase.SendData(int) EPaperBase.SendData(byte) EPaperBase.SendData(byte[]) EPaperBase.WaitUntilIdle() EPaperBase.Dispose() EPaperBase.Dispose(bool) object.Equals(object) object.Equals(object, object) object.GetHashCode() object.GetType() object.MemberwiseClone() object.ReferenceEquals(object, object) object.ToString()
Namespace Meadow.Foundation.Displays
Assembly EPaper.dll

Syntax

public class Ssd1608 : EPaperMonoBase, ISpiPeripheral, IDisposable, IGraphicsDisplay

Constructors

Ssd1608(ISpiBus, IDigitalOutputPort, IDigitalOutputPort, IDigitalOutputPort, IDigitalInputPort, int, int)

Create a new Ssd1608 ePaper display object

Declaration
public Ssd1608(ISpiBus spiBus, IDigitalOutputPort chipSelectPort, IDigitalOutputPort dataCommandPort, IDigitalOutputPort resetPort, IDigitalInputPort busyPort, int width, int height)

Parameters

Type Name Description
ISpiBus spiBus

SPI bus connected to display

IDigitalOutputPort chipSelectPort

Chip select output port

IDigitalOutputPort dataCommandPort

Data command output port

IDigitalOutputPort resetPort

Reset output port

IDigitalInputPort busyPort

Busy input port

int width

Width of display in pixels

int height

Height of display in pixels

Remarks

Ssd1608
Status Status badge: working
Source code GitHub
Datasheet(s) GitHub
NuGet package NuGet Gallery for Meadow.Foundation.Displays.ePaper

The SSD1608 is a two-color display controller for ePaper displays. Data is sent to the controller via SPI and supports full screen updates only.

The SSD1608 is paired with a wide range of two color ePaper display sizes and resolutions.

Sample projects available on GitHub

Code Example

MicroGraphics graphics;

public override Task Initialize()
{
    Resolver.Log.Info("Initialize...");

    var display = new Ssd1608(spiBus: Device.CreateSpiBus(),
        chipSelectPin: Device.Pins.D02,
        dcPin: Device.Pins.D01,
        resetPin: Device.Pins.D00,
        busyPin: Device.Pins.D03,
        width: 200,
        height: 200);

    graphics = new MicroGraphics(display);

    return Task.CompletedTask;
}

public override Task Run()
{
    graphics.DrawRectangle(1, 1, 126, 32, Meadow.Foundation.Color.Black);

    graphics.CurrentFont = new Font8x12();
    graphics.DrawText(2, 2, "SSD1608", Meadow.Foundation.Color.Black);
    graphics.DrawText(2, 20, "Meadow F7", Meadow.Foundation.Color.Black);

    graphics.Show();

    return Task.CompletedTask;
}

Sample project(s) available on GitHub

Wiring Example

To control a SSD1608 from Meadow, connect the following:

SSD1608 Meadow Pin
BUSY D15
RST D14
DC D13
CS D12
CLK SCK
DIN MOSI
GND GND
3V3 3V3

If your display does not include any of the above pins, they can be omitted. Pass NULL into the constructor for the missing pin(s).

Wiring a SSD1608 to a Meadow F7

Ssd1608(ISpiBus, IPin, IPin, IPin, IPin, int, int)

Create a new Ssd1608 object

Declaration
public Ssd1608(ISpiBus spiBus, IPin chipSelectPin, IPin dcPin, IPin resetPin, IPin busyPin, int width = 200, int height = 200)

Parameters

Type Name Description
ISpiBus spiBus

SPI bus connected to display

IPin chipSelectPin

Chip select pin

IPin dcPin

Data command pin

IPin resetPin

Reset pin

IPin busyPin

Busy pin

int width

Width of display in pixels

int height

Height of display in pixels

Remarks

Ssd1608
Status Status badge: working
Source code GitHub
Datasheet(s) GitHub
NuGet package NuGet Gallery for Meadow.Foundation.Displays.ePaper

The SSD1608 is a two-color display controller for ePaper displays. Data is sent to the controller via SPI and supports full screen updates only.

The SSD1608 is paired with a wide range of two color ePaper display sizes and resolutions.

Sample projects available on GitHub

Code Example

MicroGraphics graphics;

public override Task Initialize()
{
    Resolver.Log.Info("Initialize...");

    var display = new Ssd1608(spiBus: Device.CreateSpiBus(),
        chipSelectPin: Device.Pins.D02,
        dcPin: Device.Pins.D01,
        resetPin: Device.Pins.D00,
        busyPin: Device.Pins.D03,
        width: 200,
        height: 200);

    graphics = new MicroGraphics(display);

    return Task.CompletedTask;
}

public override Task Run()
{
    graphics.DrawRectangle(1, 1, 126, 32, Meadow.Foundation.Color.Black);

    graphics.CurrentFont = new Font8x12();
    graphics.DrawText(2, 2, "SSD1608", Meadow.Foundation.Color.Black);
    graphics.DrawText(2, 20, "Meadow F7", Meadow.Foundation.Color.Black);

    graphics.Show();

    return Task.CompletedTask;
}

Sample project(s) available on GitHub

Wiring Example

To control a SSD1608 from Meadow, connect the following:

SSD1608 Meadow Pin
BUSY D15
RST D14
DC D13
CS D12
CLK SCK
DIN MOSI
GND GND
3V3 3V3

If your display does not include any of the above pins, they can be omitted. Pass NULL into the constructor for the missing pin(s).

Wiring a SSD1608 to a Meadow F7

Methods

Initialize()

Initialize the display

Declaration
protected override void Initialize()

Overrides

Remarks

Ssd1608
Status Status badge: working
Source code GitHub
Datasheet(s) GitHub
NuGet package NuGet Gallery for Meadow.Foundation.Displays.ePaper

The SSD1608 is a two-color display controller for ePaper displays. Data is sent to the controller via SPI and supports full screen updates only.

The SSD1608 is paired with a wide range of two color ePaper display sizes and resolutions.

Sample projects available on GitHub

Code Example

MicroGraphics graphics;

public override Task Initialize()
{
    Resolver.Log.Info("Initialize...");

    var display = new Ssd1608(spiBus: Device.CreateSpiBus(),
        chipSelectPin: Device.Pins.D02,
        dcPin: Device.Pins.D01,
        resetPin: Device.Pins.D00,
        busyPin: Device.Pins.D03,
        width: 200,
        height: 200);

    graphics = new MicroGraphics(display);

    return Task.CompletedTask;
}

public override Task Run()
{
    graphics.DrawRectangle(1, 1, 126, 32, Meadow.Foundation.Color.Black);

    graphics.CurrentFont = new Font8x12();
    graphics.DrawText(2, 2, "SSD1608", Meadow.Foundation.Color.Black);
    graphics.DrawText(2, 20, "Meadow F7", Meadow.Foundation.Color.Black);

    graphics.Show();

    return Task.CompletedTask;
}

Sample project(s) available on GitHub

Wiring Example

To control a SSD1608 from Meadow, connect the following:

SSD1608 Meadow Pin
BUSY D15
RST D14
DC D13
CS D12
CLK SCK
DIN MOSI
GND GND
3V3 3V3

If your display does not include any of the above pins, they can be omitted. Pass NULL into the constructor for the missing pin(s).

Wiring a SSD1608 to a Meadow F7