工具:Typora (markdown编辑器) + Pandoc + reveal.js

如果需要使用 pandoc 命令,则需将 pandoc 添加到 path 环境变量中

Pandoc

pandoc如果没有指定输入文件则从stdin读取,并且使用stdout作为默认输出。可以使用 -o选项指定输出文件:

pandoc -o output.html input.txt

pandoc 自行安装

文件转换

官方提供了各种转换示例:Pandoc - Demos

还可在线尝试 Pandoc:Try pandoc!

直接使用 pandoc 命令(使用其默认模板)

转换为word:

pandoc -f markdown -t docx file.md -o file.docx

转换为 html:

pandoc file.md -o file.html -s

转换为pdf:

pandoc test.txt -o test.pdf

直接使用pandoc,遇到如下提示:

pdflatex not found. Please select a different --pdf-engine or install pdflatex

直接使用pandoc命令,使用的是其默认的模板,往往得不到自己想要的效果,所以建议利用 Typora 完成markdown 到其它文件格式的转换。使用 Typora 调用 Pandoc,好处就是转换后的文档格式就是Typora中所显示的格式。

比如中Typora中markdown与word的互转:

在Typora中:Typora > 文件 > 导入/导出 选择 word格式即可。(markdown中的数学公式可以转换到word中。)

Pandoc具有模块化设计:它由一系列读出器和一系列编写器组成的,读出器用于以给定格式分析文本并生成一份此文档的本地表示,编写器则用于将这份本地表示转换为目标格式。因此,增加某种输入或输出格式只需要增加一个读出器或编写器就可以了。

查看转换为pdf使用的默认模板:

pandoc -D latex

转换为幻灯片(slides)

目前Pandoc包含了对五种HTML幻灯片框架的支持:

当然,你实际上可以使用任何喜欢的幻灯片框架,只要让Pandoc在渲染HTML时使用你指定的模板(使用-t选项)即可。

使用dzslides,转换为ppt 的示例:

pandoc slides.md -o slides.html -t dzslides -s

选项 -s 的作用:(表示不理解)

By default, pandoc produces a document fragment. To produce a standalone document (e.g. a valid HTML file including <head> and <body>), use the -s or --standalone flag:

另:使用-s / - standalone选项时,pandoc使用模板添加自立文档所需的页眉和页脚材料

pandoc -s -o output.html input.txt

在直接转换成html文件的时候感觉加不加-s没啥大的区别,但在制作幻灯片时必须加 -s选项

HTML fragment:
pandoc README -o example1.html

Standalone HTML file:
pandoc -s README -o example2.html

在这些框架中 Reveal.js 的设计风格(字体、HTML5/CSS3效果)比起前面几个框架更加现代,所以推荐使用 Reveal.js。

虽说reveal.js本身就提供对Markdown语法的支持.。不过使用Pandoc的好处很明显,那就是一条命令解决问题,不需要用户接触任何HTML,使用简单。缺点就是需要安装 pandoc ,而reveal.js只有几M大小的Js文件而已,且使用 reveal.js 可以更容易进行深度定制。

下文将介绍 reveal.js 的使用。

直接使用Reveal.js

下载 reveal.js文件里面提供了一个模板文件 index.html 和 一个示例文件 demo.html 。

我们在创建幻灯片时,可以复制index.html文件内容,并在其基础上更改,找到文件中类似下面的标签,并在里面添加幻灯片。

		<div class="reveal">
			<div class="slides">
				<section>Slide 1 幻灯片1的内容</section>
				<section>Slide 2 幻灯片2的内容</section>
                  <section data-markdown> 使该幻灯片支持 markdown 语法</selection>
                  <section data-transition="值">为该幻灯片 使用特定转场动画,值可以是:fede,slide,convex,concave,zoom,none</section>
                  <section data-background="#000">为该幻灯片指定背景色</section>
                  <section data-background-image="图片路径">为该幻灯片指定背景图片</section>
                <section data-background-video="视频地址">为该幻灯片指定背景视频</section>
			</div>
		</div>

如果还嫌不够,顺便说一句,Reveal.js 支持 javascript,所以其应用场景可不限于传统的演示文稿——如果你想做一个现场投票、幸运转盘抽奖,都没问题。这些有趣的拓展功能都内嵌在你的 Reveal.js 版「PPT」里 。

参考: Reveal.js:把你的 Markdown 文稿变成 PPT - 少数派

更详细的使用见文档:GitHub - hakimel/reveal.js: The HTML Presentation Framework

使用Pandoc和Reveal.js制作幻灯片

转换所用文本(示例文本,标准文本):

% Habits
% John Doe
% March 22, 2005

# In the morning

## Getting up

- Turn off alarm
- Get out of bed

## Breakfast

- Eat eggs
- Drink coffee

# In the evening

## Dinner

- Eat spaghetti
- Drink wine

------------------

![picture of spaghetti](https://s2.51cto.com/images/100/blog/error_t.png)

## Going to sleep

- Get in bed
- Count sheep

该文本来自: Pandoc - Pandoc User’s Guide

为了让Pandoc对不包含任何元信息的Markdown文本进行处理生成幻灯片,在文本开头需要包含三行以%打头的元信息:标题、作者和日期。

首先需要从GitHub上获取https://github.com/hakimel/reveal.js,并将reveal.js同名的文件夹放在幻灯片所在目录下即可:

使用git克隆,或者直接下载reveal.js的压缩包.

$ git clone https://github.com/hakimel/reveal.js

渲染幻灯片:

$ pandoc slides.md -o slides.html -t revealjs -s

除了默认的外观主题以外,reveal.js 还提供了多个主题可供选择

$ pandoc slides.md -o slides.html -t revealjs -s -V theme=beige

reveal.js主题:

  • default:(默认)深灰色背景,白色文字
  • beige:米色背景,深色文字
  • sky:天蓝色背景,白色细文字
  • night:黑色背景,白色粗文字
  • serif:浅色背景,灰色衬线文字
  • simple:白色背景,黑色文字
  • solarized:奶油色背景,深青色文字

如果你用于转换的markdown文件格式不符合要求,可能会出现如下警告:

 pandoc Pandoc.md -o slides.html -t revealjs -s -V theme=night
[WARNING] This document format requires a nonempty <title> element.
  Please specify either 'title' or 'pagetitle' in the metadata.
  Falling back to 'Pandoc'

-V选项:

模板包含变量(variables),它的作用是允许在文件中的任何位置包含任意信息。 可以使用-V / - variable选项在命令行中设置它们 。

如果未设置变量,pandoc将在文档的元数据中查找对应的值。元数据 可以使用YAML metadata blocks--metadata选项进行设置。

YAML metadata blocks:就是出现在文档顶部,且使用两个 --- 包围起来的部分。

幻灯片的分隔依据

内容整理自: Pandoc - Pandoc User’s Guide

默认情况下,幻灯片级别是层次结构中的最高标级别,后面紧跟内容,而不是文档中某处的一个标题。在上面的示例中,级别1标题后面始终跟有2级标题,后跟内容,因此2是幻灯片级别。

1级标题In the morning后面紧跟2级标题Getting up,而2级标题Getting up后面的内容是显示在幻灯片上的主体内容,因此这里的Slide level为2。这意味着每个2级标题生成一张幻灯片。高于2级的标题(1级标题)生成一张独立的仅包含标题的幻灯片,而低于2级的标题(3级标题)将存在于上一级标题的幻灯片中,不单独生成新的幻灯片.

可以使用--slide-level选项覆盖默认的Slide level。

在reveal.js模板下,由于幻灯片的滚动方向可以是二维的(键盘→←↑↓),所以1级标题渲染为水平方向的幻灯片,2级标题渲染为竖直方向的幻灯片。

为了生成合适的用于演示的HTML文档,需要记住的另一点是:在默认情况下每个二级标题是一张独立的幻灯片。这样在写作的时候,只需注意把每个二级标题下的内容控制在适当的长度。

这里幻灯片的布局格式:

+---------+     +---------+    +---------+
|         |     |         |    |         |
+---------+     +---------+    +---------+

+---------+     +---------+    +---------+
|         |     |         |    |         |
|  slide1 |     |  slide1 |    |  slide1 |
|         |     |         |    |         |
+---------+     +---------+    +---------+

+---------+     +---------+    +---------+
|         |     |         |    |         |
| slide2  |     | slide2  |    | slide2  |
|         |     |         |    |         |
+---------+     +---------+    +---------+

根据以下规则将文档划分为幻灯片:

  • 水平规则 始终会分割出一个新幻灯片(对应上文的 ----------),即可以使用分割线来强行生成新的幻灯片。分隔线的使用场景我想因该是当你的内容在一张幻灯片上装不下时使用。
  • 幻灯片级别的 标题 始终会分割出一个新幻灯片。
  • .....(看不懂)

文件编码必须是 utf-8,否则当文件中出现中文时会产生如下错误:

pandoc: Cannot decode byte '\xe3': Data.Text.Internal.Encoding.decodeUtf8: Invalid UTF-8 stream

渐进显示的列表

比如有如下列表:

  • 列表项1
  • 列表项2

你希望展示时先显示列表项1,之后点击向下箭头后再显示列表项2,则可使用下面的 fenced div语法:

::: incremental

- 列表项1i
- 列表项2

:::

这里 :::对表示这是一个 div, 而 incremental表示它所属的 class

<div class=incremental>
    
</div>

或者在生成幻灯片时加入-i选项,用于控制列表的显示效果(逐条渐入)

$ pandoc slides.md -o slides.html -t revealjs -s -i

插入暂停

使用带空格的三个点 . . .即可插入在两段文字显示之间的人为停顿

## 暂停

暂停之前

. . .

暂停之后

建议直接复制上面的三个点

幻灯片主题

这里所有的配置 reveal.js configuration options 都可通过变量形式进行设置。比如主题可以使用 theme变量来进行设置:

-V theme=moon

我们找到上面 url 中所列的 keyboard来进行测试:

pandoc test01.txt -o slides.html -t revealjs -s  -V theme=simple -V keyboard=false

效果是我们在生成的幻灯片中不能使用键盘的方向键来切换幻灯片。

提示板

notes应该是为了给演讲者相应的提示的内容,Notes使用如下格式:

::: notes

这是我的笔记.

- 它可以包含 Markdown
- 比如这个列表
- 只有按 s 键,notes才会显示

:::

默认看不到notes,只有按 s 键,notes才会显示。

并排显示

可以添加多个列,只需将对应的 divclass设置为columns并且为 width属性设置值。示例:

:::::::::::::: {.columns}
::: {.column width="40%"}
contents...
:::
::: {.column width="60%"}
contents...
:::
::::::::::::::

设置背景

Sorry: 在我的windows中就是提示找不到本地图片,可能路径有问题

当使用在线图片是可以显示的,可能会有点慢(在尝试了几次后才加载出来)

为每个幻灯片设置同一个背景图片:

使用配置选项 parallaxBackgroundImage ,可以 在YAML元数据块中或作为命令行变量 使用该选项。 

You can also set parallaxBackgroundHorizontal and parallaxBackgroundVertical the same way and must also set parallaxBackgroundSize to have your values take effect.

为单独的某个幻灯片设置背景图片:

在第一个幻灯片级别的头部添加 {data-background-image="/path/to/image"}

add {data-background-image="/path/to/image"} to the first slide-level header on the slide (which may even be empty).

其它的一些 background 设置也可以在单独的某个幻灯片上使用,包括:

data-background-size, data-background-repeat, data-background-color, data-transition, and data-transition-speed.

查看 reveal.js documentation 文档以了解更多细节 ( 一定要看 )。

示例:

---
title: My Slideshow
parallaxBackgroundImage: /path/to/my/background_image.png
---

## Slide One

Slide 1 has background_image.png as its background.

## {data-background-image="/path/to/special_image.jpg"}

Slide 2 has a special image for its background, even though the header has no content.

In reveal.js’s overview mode, the parallaxBackgroundImage will show up only on the first slide. 只会在第一个幻灯片上显示

代码高亮风格

控制代码高亮风格的选项有:

  • --highlight-style pygments
  • --highlight-style kate
  • --highlight-style monochrome
  • --highlight-style espresso
  • --highlight-style haddock
  • --highlight-style tango
  • --highlight-style zenburn

参考: 桌面应用|Markdown+Pandoc→HTML幻灯片速成

来自于我的简书:faner - 简书