Looking for the 'perfect' presentations' solution (for me)

Presenting at ‘Collaborative Cartographies’ (October 19th, 2019)

During the last 10 years I have given a number of talks in various contexts due to my job as a lecturer: either lectures for my students, conferences, workshops or even much more informal events, usually speaking about cities, commons, maps or accessibility. I enjoy it because I love sharing knowledge with others but also because it is when I am preparing presentations (by summarising and highlighting the main topics or thinking of the storytelling) where I reflect and learn the most. It is for that reason that I am always looking for the right software that allows me to create appealing slides in a relatively fast way. In this post, I will be sharing some of the decisions I have made and the results I got regarding that matter.

In order to prepare my presentations I have used and tested several presentation softwares and services, such as the classic Powerpoint, LibreOffice Impress (View example), Google Slides or, Prezi (Example, Example). All of them are really good pieces of software and you can create great presentations with them. However, as time goes by, I have become more concerned with techno-politics and data autonomy on the one hand, and with efficiency on the other. As a result, I have come to outline the following list of requirements that my software of choice should have:

  1. It must allow me to own my (own) data and to easily reuse and share it with others for any purpose.
  2. It should be opensource.
  3. It must allow offline editing and displaying.
  4. It must allow adding content without having to worry about formatting it. Ideally, I should be able to write in plain text or markdown (or the like) which will later be formatted and converted into a final good-looking format. I want to focus on adding content very fast for scaffolding it: I want to edit it in plain text or markdown.
  5. It should look good (uh!)

So, with those requirements in mind, I started to look for candidates that would fit in those selection criteria. After a while, I ended up with the following shortlist1:

  • LibreOffice Impress: a conventional desktop software for presentations. It is opensource and multiplatform and it is part of the LibreOffice suite.
  • Impress.js: a presentation framework based on the power of CSS3 transforms and transitions in modern browsers and inspired by the idea behind prezi.com. It allows moving through an infinite canvas, like the former, but also in 3D!
  • Reveal.js: an HTML presentation framework. Halfway between the two others, as it creates slides' decks that can be opened with any web browser with a two-axis' navigation (unlike regular presentation software that only allows linear navigation).

Let’s see how the competitors behave regarding each of my requirements:

       LO Impressimpress.jsreveal.js
# 1: Own dataYesYesYes
# 2: FLOSSYesYesYes
# 3: OfflineYes (ODP or PDF)Yes (Local html)Yes (Local html file or PDF)
# 4: Format-hassle-freeNo (although using styles makes things easier and are almost as valid workaround)Yes, using hovercraftYes (multiple approaches)
# 5: AppealingWith effortSomewhatYes!

And now, let me further elaborate this summary table.

LibreOffice Impress

LibreOffice is a traditional desktop software that could be considered as the opensource replacement for Powerpoint. It creates regular slides' deck and offers several templates with designs and layouts. Although I acknowledge that from LO foundation have put an effort into designing new templates and the stock defaults have improved dramatically, I cannot but help to consider that they still look somewhat oldies/traditional. However, I also admit that this is a completely subjective matter and can be fixed by either dowloading one of the many available templates or by creating our own. After all, and to be completely honest, I have done so for many years.

Since it is a regular desktop software that means that it has to be installed in your computer if you want to edit your presentation. But if you do not have it installed, you can use any of the many softwares capable of reading ODP format, which is an open ISO standard or you can bring your own Portable Edition that can be run from a USB stick or the like without installing it in the computer. But if you only want to visualize the presentation, you can always export to PDF using the built-in feature (just one click), which is always an insurance that your presentation will always look the way you wanted it to be (custom fonts, I am looking at you!).

In order to add content you need to create text boxes, insert images, tables… add transitions, slides… using its GUI. This may seem a good thing, as it allows you to easily align objects and modify them on the fly. However, in my experience I found that approach to be very time consuming, as it often requires resizing objects, changing text-sizes, aligning, changing image properties… The good news is that LibreOffice’s styles are a really powerful tool when used correctly. Styles allow customizing anything we want, starting from layouts but also paragraph styles, lists, images, tables… It may take some time to customize every style, but once you’re done, it pays the effort: all your objects will look consistently and exactly the way you want without doing anything else. And if you ever change your mind… they will update automatically, preserving their consistency. Great, isn’t it?!

Another inconvenient for me is that it is not easy to work with media other than images (like videos, websites, maps…), especially if they are not stored locally or require some interaction.

Pros:

  • ✅ Ease of use
  • ✅ Compatibility (in terms of format an collaboration)
  • ✅ Customization
  • ✅ Risk-free: export to PDF for your peace of mind
  • ✅ Presenter’s console

Cons:

  • ❌ Content editing is time consuming
  • ❌ No GIFs! or other interactive media
  • ❌ Outdated (default) appearance from the 90s
  • ❌ Only linear presentations

Impress.js

Clic on the text and use arrows to browse the presentation

I have to admit that I love Prezi because, unlike all the others, instead of working with independent slides that are displayed linearly, you can work with an infinite canvas that works at different scales at the same time. This allows plenty of completely different possibilities: you can literally go from the big picture to the smallest of the details. Or even the other way round: you can start with details that slowly conform a broader reality. Or, if you want, you can also use traditional slides. Everything seemed perfect, except that it is not opensource and all your data is locked in a closed platform and does not comply with any of my requirements.

A sample presentation I did for Digital Tools' course at Universidad San Jorge using Prezi

Admittedly, I am so in love with it that I did my best looking for a good replacement. After discarding Sozi I discovered impress.js. Impress.js is a framework that benefits from Javascript and CSS3 properties and transitions that can virtually mimic Prezi in everything (plus the addition of being able to add 3D transitions and transformations). Since it produces HTML files, they can be opened by any web browser and can include any type of media (even other embedded websites!). Also, it means that anything can be tweaked by using CSS. However, writing HTML is far from being fast, as it requires a lot of tags that need to be opened and closed.

The good news is that there is hovercraft! Hovercraft lets you write your content in reStructuredText, which is very similar to markdown and, hence, very fast to write and read and it converts your text into a fully functional impress.js' website. It really has the good features of the two worlds, as it combines ease of editing with impressive results.

The only drawback is that it is not easy to create custom navigations (eg. following a path) nor to tweak the default (and basic) CSS styles2.

Pros:

  • ✅ Non-linear presentations
  • ✅ Easy to add content by writing RST files
  • ✅ Can be displayed in any web browser
  • ✅ Presenter’s console
  • ✅ Accepts any type of media

Cons:

  • ❌ Basic CSS styles
  • ❌ Difficult to edit paths
  • ❌ You need to have hovercraft installed in your computer to create the output files
  • ❌ I have not succeeded in achieving the same results as with Prezi (in terms of navigation, expressiveness and story-telling)

Reveal.js

And here it comes my currently preferred software for creating my presentations: Reveal.js. Like Impress.js it is a framework that creates an html file (with some javascript to do its magic -hence the .js suffix) that can be displayed in any device with a web browser. Also, since it follows HTML and CSS standards, and it is responsive by default, this means that can be seen in any computer, tablet or smartphone, with minor differences3.

Another feature I like a lot about reveal.js is that whereas it does not allow to design custom and complex paths like impress.js it allows using nested slides, which provides two-axis of displacement: you can move to the right-left like in regular slides' decks and also top-down. This means that, when used wisely and consistently, it provides plenty of visual resources, which is very useful for communication purposes (at least for all of those who, like me, have a very visual memory).

Also, since it is relatively new, and it is a very popular opensource project with many contributors4 I find their slides to be very appealing and contemporary. And talking about its appearance, reveal.js can be customized in several ways: either changing the transitions between the slides and/or choosing from one of the several default themes (all of which look quite good) or easily customize them (or even create our own) by using .scss language, as I did below:

A presentation I made using reveal.js for the Urban Studies I course at Universidad San Jorge. You can see it [fullscreen here](https://ccamara.github.io/slides/02-Greek-roman-cities) (which is where it shines!)

I know what you may be thinking now: “But hey! you’ve talked about .html, .css, .js and .scss, which are languages that are quite verbose and therefore it does not comply with your requirement #4, as writing a presentation in .html can be really cumbersome." You’re right. And wrong. While this is true by default, the good news is that there are several ways to write in markdown, a language that I have come to love due to its simplicity, speed and versatility (in fact, this whole website is written in markdown). But since there are several ways to do it and this has resulted in an already long post, I will talk about it in an upcoming one.

Pros:

  • ✅ Can be displayed in any web browser
  • ✅ Looks great (nice default SCSS templates, which can be easily extended)
  • ✅ Presenter’s console (you know, with a timer, presenter notes and next-slide preview)
  • ✅ Accepts any type of media
  • ✅ Can create sections and sub-sections
  • ✅ Easy to add content by writing in markdown plain text (there are many approaches to generate the HTML files from plain text -more on that in an upcoming blog post)

Cons:

  • ❌ Not for everyone (may not be ideal if you are to collaborate with other people not familiar with markdown, html, css, git…) (but hey! there is also an online editor as a freemium service)
  • ❌ Requires some time to set up
  • ❌ May not look the same in every device
  • ❌ PDF export requires Chrome/Chromium, and still doesn’t look as nice as the original

  1. I am also aware of the existence of other solutions that may meet my requirements, but I haven’t had the time to try them out, such as https://remarkjs.com/ or https://www.emaze.com/ . If you happen to know more that may fit on my requirements, please feel free to share them with me in the comments. ↩︎

  2. You can see some of the attempts I made on this repo. ↩︎

  3. The truth is that depending on the screen resolution and the use of custom fonts, the result may differ slightly (or greatly). ↩︎

  4. At the time of writing this post, 255 different people have contributed to reveal.js in more than 2,400 different commits. Source: https://github.com/hakimel/reveal.js ↩︎

Carlos Cámara-Menoyo
Carlos Cámara-Menoyo
Architect. PhD. Lecturer. Life-long Learner. Transdisciplinary.

I love learning, teaching and researching, as well as sharing and visualizing data, specially with maps. I have a technical and social background and my multiple research interests are centered around the commodifications between cities, technology and society within informationalism and free culture paradigm. So far, I have applied that approach on the topic of social and spatial inequities.

comments powered by Disqus

Related