Skip to content

Images#

Images are put into the slides by calling .image() on a box. It creates a new box with an image. Nelsie supports the following formats: SVG, PNG, JPEG, and OpenRaster.

@deck.slide()
def image_demo(slide):
    slide.image("./imgs/nelsie-logo.jpg")

Note for Elsie users

Calling .image() creates a new box; this is a different behavior than in Elsie, where calling .image() does not create a new box.

Image box#

The .image() method also takes the same arguments as .box(), which are passed to the underlying box of the image. The main purpose is to set the image size. If only width or only height is set, the other coordinate is automatically calculated to maintain the aspect ratio of the image.

@deck.slide()
def image_demo(slide):
    slide.image("./imgs/nelsie-logo.jpg", width="50%")

If both width and height are specified, image will try to fill the box while maintaining the aspect ratio; so part of the box may not be covered by the image.

@deck.slide()
def image_demo(slide):
    slide.image("./imgs/nelsie-logo.jpg", width="50%", height="300", bg_color="green")

Image directory#

A directory where images are searched for can be configured via image_directory.

# Set image directory globally
deck = SlideDeck(image_directory="path/to/images")


# Set image directory per slide
@deck.slide(image_directory="path/to/images")
def my_slide(slide):
    ...

Image and steps#

Formats that supports layers (SVG and OpenRaster) may control revealing a part of image in steps by naming layers. JPEG, and PNG image does not have any impact on steps.

If a layer has a name that ends with **EXPR where EXPR is an expression allowed in box's show argument, except for last/next/last+/next+ keywords. Keywords are not allowed in an image step definitions. Example: A layer with name "My layer **2-4" will be shown only steps 2, 3, 4.

Example#

The following OpenRaster image contains three layers. The following screenshot shows layer names of the image when opened in Krita.

Screenshot of Krita

When the image is used in a slide, it generates three steps:

@deck.slide()
def image_demo(slide):
    slide.image("./imgs/stepped_logo.ora")
1/3

The same works also for SVG images. SVG layer names can be editor for example in Inkscape.

Disabling steps#

The definition of steps in an image can be disabled with enable_steps=False. All layers will be drawn normally.

@deck.slide()
def image_demo(slide):

    # The slide will have just one step, as step definitions are ignored in the image.
    slide.image("./imgs/stepped_logo.ora", enable_steps=False)

Shifting steps#

Step definitions in an image may be shifted via shift_steps argument. It basically adds a constant to all step definitions in an image.

@deck.slide()
def image_demo(slide):

    # The first image will be shown at step 3
    slide.image("./imgs/stepped_logo.ora", shift_steps=2)
1/3

Directly passing image data#

You can pass directly image data into .image() method. Data has to be passed as tuple (<data>, <format>). <format> has to be one of the following values: "png", "jpeg", or "svg".

@deck.slide()
def image_data_demo(slide):
    png_data = ...  # some bytes
    slide.image((png_data, "png"))