工具: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幻灯片框架的支持:

  • DZSlides
  • Slidy
  • S5
  • Slideous
  • reveal.js

当然,你实际上可以使用任何喜欢的幻灯片框架,只要让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.htmlStandalone 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](images/spaghetti.jpg)## 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 &lt;title&gt; 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

&lt;div class=incremental&gt;&lt;/div&gt;

或者在生成幻灯片时加入-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 OneSlide 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 - 简书

转载于:https://blog.51cto.com/13853366/2351878

Pandoc中使用Reveal-js制作幻灯片相关推荐

  1. 如何使用Emacs Org模式和Reveal.js创建幻灯片

    在过去的一年左右的时间里,我开始大量重新使用Emacs和Org模式包(用于记录笔记,组织自己等等). 我也开始将脚趾浸入水中,进行简短的演讲. 我一直在想如何将Emacs与演讲结合起来. 演示与文本编 ...

  2. 使用reveal.js制作精美的网页版PPT

    前言 最近在做季度总结和技术分享,所以需要做个PPT, 来回顾这半年来的技术贡献. 但苦于mac上运行PPT那感人的流畅度, 成功的激起了笔者的强迫症, 所以索性想办法通过技术的手段来做个网页版PPT ...

  3. 使用reveal.js制作一个酷炫的网页ppt

    今天教大家使用reveal.js,制作一个简洁优雅的网页ppt.在这之前,你需要一些基本的HTML以及CSS的技能基础. 1.准备工作 下载插件,插件下载地址:https://github.com/h ...

  4. 使用reveal.js制作PPT,并部署至GitHub

    折腾了一天把PPT做好,经历千辛万苦终于上传到Github上实现预览,记下啦,以免下次再用的时候忘掉 制作PPT 一.安装reveal.js 1.基本安装(我觉得写个PPT,基本安装就可以啦) clo ...

  5. 用html+css+js制作幻灯片显示

    用setTimeout制作幻灯片动画.装载网页后自动播放幻灯片. 当mouseover图片时,显示左右箭头,并停止动画.当mouseout画面时,隐藏左右箭头,重新启动动画. 每次点击左箭头将移动一副 ...

  6. 支持javascript的ppt软件_用 reveal.js 随心所欲地制作 PPT

    在面临课题总结或者小组活动的时候,我们几乎都避免不了使用PPT的情境.而制作一个质量较高的PPT可能需要花费比较长的时间1 .倘若你是个"完美主义者",对细节要求几近苛刻,而知识储 ...

  7. angular项目引入reveal.js

    angular项目引入reveal.js 一 背景 二 解决方案 1 引入reveal.js 2 在angular.json的styles中引入reveal.js的css样式,作为全局样式. 3 修改 ...

  8. reveal.js + markdown 制作幻灯片

    reveal.js + markdown 制作幻灯片--0 reveal.js是一款通过利用HTML快速创建演示文稿,并且具有很多功能:垂直,水平幻灯片:支持Markdown,LaTex:演讲者注释: ...

  9. reveal.js + markdown 制作幻灯片——配置选项,幻灯片背景,尺寸,插入媒体,链接

    reveal.js + markdown 制作幻灯片--配置选项,幻灯片背景,尺寸,插入媒体,链接 配置选项 配置选项在index.html文件的<body>中,通过Reveal.init ...

最新文章

  1. Gartner:为什么每一位首席执行官都应重视物联网并为其投资?
  2. C# Http方式下载文件到本地类改进版
  3. Qt 实现数据协议控制--组帧、组包、解析帧、解析包
  4. CNN结构:SPP-Net为CNNs添加空间尺度卷积-神经元层
  5. 零空间追踪 matlab,中国科学院自动化研究所
  6. c++获取ctrl+v内容_WPS表格——CTRL快捷键的用法
  7. spring-kafka广播模式配置_交换机为什么要划分vlan?交换机如何配置
  8. 2016-2017 华为中兴笔试+测评+技术面+综合二面+洽谈经验
  9. 百度离线地图——瓦片地图下载
  10. 互联网金融反欺诈体系
  11. steam无法连接至计算机,无法连接至steam网络怎么办 无法连接至steam网络解决方法【图文】...
  12. CentOS挂载光盘镜像安装rpm包
  13. strtolower() 函数
  14. 导数卷积 牛客 NTT
  15. 蓝蓝算法第二期,T51
  16. 关于jmeter中编写shell脚本json的应用
  17. margin-top遇到的小问题
  18. bhu1272小希的迷宫
  19. 前端培训班出身——吐槽下16年的艰辛
  20. 【Flutter 异步编程 - 捌】 | 计算耗时? Isolate 来帮忙

热门文章

  1. java 将对象写入链表_在Java中,_____类可用于创建链表数据结构的对象。
  2. rmf 文件如何打开?
  3. 微信小程序开发(五)——数据绑定、运算、样式导入、页面跳转
  4. Android系统设置settings应用学习(二)--源代码解析
  5. 分享10个实用的软件和网站,我每天都在用
  6. VT系列一:VT简述
  7. 什么方法可以将pdf压缩到最小
  8. 淘宝API关键词搜索接口调用示例
  9. 信用评分卡Credit Scorecards (1-7)
  10. iphone6 问题总结