Skip to content

A literate programming environment for PowerPoint

License

Notifications You must be signed in to change notification settings

ender8848/Geekppt

Repository files navigation

Geekppt example workflow

A powerful slide making tool -- execute code in textbox

This is a MSc Computing group project in Imperial College London -- "A literate programming environment for PowerPoint".

Prominent literate programming environments nowadays are Jupyter notebooks, Mathematica, emacs' org-mode, etc. While all of them can produce slides, none of them supports the generation of PowerPoint presentations.

In this project, we aim to build a ppt addin called Code Evaluation that helps quickly insert code output, such as print and pictures in ppt, and enable command line and table input. This addin also supports shortcut conversion from multiple types to pptx while preserving all fhe features above.

Installation

published version

User Guide

Prerequisites

need to install functionality
g++ C++
JDK Java
Python3 Python
Pandoc conversion to pptx file

PowerPoint 2016 or later.

Create codebox, click to execute

Click on a language button to create a codebox. For example, to create a Python codebox, simply click on the Python button, type in some code (such as print("Hello")). To execute the code, click the evaluate button, "Hello" will be shown in a newly inserted textbox.

Currently the addin supports C++, Java and Python. It is worth noting that using C++ and Java requires creating main function and helper functions with different buttons. Before executing main function with multiple helper functions, make sure they are the same language, then choose them all and click evaluate to get results.

Add input to you code

Adding inputs can be easy using the General Inputs button. After creating a input box, choose it with codeboxes that requires input, click evaluate to get results.

Graphical output

Graphical output can be triggered using plt.show() in Python. A plt.show() will result in a figure inserted in current slide. You can use multiple plt.show() to insert many images. The addin does not support plt.show() in loops.

Copy the following Python code in a codebox and try evaluate it to check the effect.

import numpy as np
import matplotlib.pyplot as plt

x = np.linspace(0, 5, 100)  # Sample data.
fig, ax = plt.subplots(figsize=(6, 2.7))

ax.plot(x, x, label='linear')
ax.plot(x, x**2, label='quadratic')
ax.plot(x, x**5, label='pow5') 
ax.set_xlabel('x label')
ax.set_ylabel('y label')
ax.set_title("Simple Plot")
ax.legend()
plt.show()

Parameter table and plot template

Use Parameter Table button to generate a parameter table where you can add any row or column and write data into cells. The first row of the table defaults to the table name, which means that it will not be entered as an argument. It would help if you replaced the table name with the appropriate place in the code block to ensure it doesn't go wrong.

You can then select a parameter table and click the Plot Template button to generate a block of Python code. Using it, you can draw a simple scatter plot (based on the data in the table).

Conversion to ppt with codebox enabled

User can firstly use pandoc to convert Markdown file to PowerPoint file. In order to make addin detect certain language type, the users need to add specific tags for different language codebox (@code_python for python, @code_java_main & @code_java for Java, @code_cpp_main & @code_cpp for C++). For example, python code should be marked like this in md files.

@code_python
# code content
@code_python

Then users can use Reformat button to remove all existing tags(users can also run code without reformating). After clicking the reformat button, users can run code by clicking evaluation button.

Technical Documentation

For full documentation for the PowerPoint add-in, please go to Code Evaluation: Code Evaluation (luowx0905.github.io)

License

Geekppt is released under the MIT License. https://opensource.org/licenses/MIT

About

A literate programming environment for PowerPoint

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published