Class: Toybox::Graphics::Dc

Inherits:
Lang::Object show all

Overview

Note:

You should never directly instantiate a Dc object, or attempt to render to the screen outside of an onUpdate call.

This class represents a device context.

It provides methods to perform drawing operations on the device.

Examples:

Draws a blue rectangle using direct pixel parameters.

using Toybox.Graphics;
function onUpdate(dc) {
    dc.setColor(Graphics.COLOR_BLUE, Graphics.COLOR_BLACK);
    dc.fillRectangle(100, 100, 100, 100);
}

Draws a red circle using direct pixel parameters.

using Toybox.Graphics;
function onUpdate(dc) {
    dc.setColor(Graphics.COLOR_RED, Graphics.COLOR_BLACK);
    dc.fillCircle(50, 100, 75);
}

Draws “Hello World” in the center of the screen using calls to the Device Context (dc).

using Toybox.Graphics;
function onUpdate(dc) {
    dc.setColor(Graphics.COLOR_BLACK, Graphics.COLOR_TRANSPARENT);
    dc.drawText(
        dc.getWidth() / 2,                      // gets the width of the device and divides by 2
        dc.getHeight() / 2,                     // gets the height of the device and divides by 2
        dc.FONT_LARGE,                          // sets the font size
        "Hello World",                          // the String to display
        Graphics.TEXT_JUSTIFY_CENTER            // sets the justification for the text
                );
}

Clears the screen of device with background color (Graphics.COLOR_BLACK).

using Toybox.Graphics;
function onUpdate(dc) {
    dc.setColor(Graphics.COLOR_BLACK, Graphics.COLOR_BLACK);
    dc.clear();
}

Since:

  • 1.0.0

Instance Method Summary collapse

Methods inherited from Lang::Object

equals, hashCode, method, toString, weak

Instance Method Details

clearObject

Erase the screen using the background color.

Since:

  • 1.0.0



3832
3833
# File 'Monkeybrains.rb', line 3832

def clear()
end

clearClipObject

Reset the drawable area to the full area of the Dc.

Since:

  • 2.3.0



4022
4023
# File 'Monkeybrains.rb', line 4022

def clearClip()
end

drawArc(x, y, r, attr, degreeStart, degreeEnd) ⇒ Object

Draw an arc.

  • 0 degrees: 3 o'clock position.

  • 90 degrees: 12 o'clock position.

  • 180 degrees: 9 o'clock position.

  • 270 degrees: 6 o'clock position.

Parameters:

Since:

  • 1.2.0



4068
4069
# File 'Monkeybrains.rb', line 4068

def drawArc(x, y, r, attr, degreeStart, degreeEnd)
end

drawBitmap(x, y, rez) ⇒ Object

Draw a bitmap to the screen.

Parameters:

Raises:

Since:

  • 1.0.0



3895
3896
# File 'Monkeybrains.rb', line 3895

def drawBitmap(x, y, rez)
end

drawCircle(x, y, radius) ⇒ Object

Draw a circle around a point.

Parameters:

Since:

  • 1.0.0



3840
3841
# File 'Monkeybrains.rb', line 3840

def drawCircle(x, y, radius)
end

drawEllipse(x, y, a, b) ⇒ Object

Draw an ellipse around a point.

Parameters:

Since:

  • 1.0.0



3851
3852
# File 'Monkeybrains.rb', line 3851

def drawEllipse(x, y, a, b)
end

drawLine(x1, y1, x2, y2) ⇒ Object

Draw a line between two points.

Parameters:

Since:

  • 1.0.0



3904
3905
# File 'Monkeybrains.rb', line 3904

def drawLine(x1, y1, x2, y2)
end

drawPoint(x, y) ⇒ Object

Draw a point on the screen.

Parameters:

Since:

  • 1.0.0



3858
3859
# File 'Monkeybrains.rb', line 3858

def drawPoint(x, y)
end

drawRectangle(x, y, width, height) ⇒ Object

Draw a rectangle.

Parameters:

Since:

  • 1.0.0



3868
3869
# File 'Monkeybrains.rb', line 3868

def drawRectangle(x, y, width, height)
end

drawRoundedRectangle(x, y, width, height, radius) ⇒ Object

Draw a rounded rectangle.

Parameters:

Since:

  • 1.0.0



3879
3880
# File 'Monkeybrains.rb', line 3879

def drawRoundedRectangle(x, y, width, height, radius)
end

drawText(x, y, font, text, justification) ⇒ Object

Draw text at the given location.

This method is not supported for anti-aliased fonts (including most built in fonts) for a BufferedBitmap that has a palette.

Parameters:

Raises:

Since:

  • 1.0.0



3971
3972
# File 'Monkeybrains.rb', line 3971

def drawText(x, y, font, text, justification)
end

fillCircle(x, y, radius) ⇒ Object

Fill a circle with the foreground color.

Parameters:

Since:

  • 1.0.0



3912
3913
# File 'Monkeybrains.rb', line 3912

def fillCircle(x, y, radius)
end

fillEllipse(x, y, a, b) ⇒ Object

Fill an ellipse with the foreground color.

Parameters:

Since:

  • 1.0.0



3923
3924
# File 'Monkeybrains.rb', line 3923

def fillEllipse(x, y, a, b)
end

fillPolygon(pts) ⇒ Object

Fill a polygon with the foreground color.

Parameters:

Since:

  • 1.0.0



3930
3931
# File 'Monkeybrains.rb', line 3930

def fillPolygon(pts)
end

fillRectangle(x, y, width, height) ⇒ Object

Fill a rectangle with the foreground color.

Parameters:

Since:

  • 1.0.0



3940
3941
# File 'Monkeybrains.rb', line 3940

def fillRectangle(x, y, width, height)
end

fillRoundedRectangle(x, y, width, height, radius) ⇒ Object

Fill a rounded rectangle with the foreground color.

Parameters:

Since:

  • 1.0.0



3951
3952
# File 'Monkeybrains.rb', line 3951

def fillRoundedRectangle(x, y, width, height, radius)
end

getFontHeight(font) ⇒ Toybox::Lang::Number

Get the height of a font.

Parameters:

Returns:

Since:

  • 1.0.0



4050
4051
# File 'Monkeybrains.rb', line 4050

def getFontHeight(font)
end

getHeightToybox::Lang::Number

Get the height of the display region that is available to the app.

Returns:

Since:

  • 1.0.0



4034
4035
# File 'Monkeybrains.rb', line 4034

def getHeight()
end

getTextDimensions(text, font) ⇒ Toybox::Lang::Array

Get the width and height of a String.

This takes new lines into account when determining the height. The width is the maximum width for a given line of the String. If a String has two newline characters (\n) in it, the height would be for three lines and the width would be the width of the longest String.

Parameters:

Returns:

Since:

  • 1.0.0



3987
3988
# File 'Monkeybrains.rb', line 3987

def getTextDimensions(text, font)
end

getTextWidthInPixels(text, font) ⇒ Toybox::Lang::Number

Get the width of a String.

Parameters:

Returns:

Since:

  • 1.0.0



4043
4044
# File 'Monkeybrains.rb', line 4043

def getTextWidthInPixels(text, font)
end

getWidthToybox::Lang::Number

Get the width of the display region that is available to the app.

Returns:

Since:

  • 1.0.0



4028
4029
# File 'Monkeybrains.rb', line 4028

def getWidth()
end

setClip(x, y, width, height) ⇒ Object

Apply a clipping region to the Dc.

Pixels outside of the region will not be affected by any operations.

Parameters:

Since:

  • 2.3.0



4017
4018
# File 'Monkeybrains.rb', line 4017

def setClip(x, y, width, height)
end

setColor(foreground, background) ⇒ Object

Set the current foreground and background colors.

Parameters:

  • foreground (Toybox::Lang::Number)

    Graphics.COLOR_* constant or 24-bit integer of the form 0xRRGGBB.

  • background (Toybox::Lang::Number)

    Graphics.COLOR_* constant or 24-bit integer of the form 0xRRGGBB.

Since:

  • 1.0.0



3996
3997
# File 'Monkeybrains.rb', line 3996

def setColor(foreground, background)
end

setPenWidth(width) ⇒ Object

Set the width of a line.

Parameters:

Since:

  • 1.0.0



4002
4003
# File 'Monkeybrains.rb', line 4002

def setPenWidth(width)
end