Maybe the best PPT webapp ever
-
markdown based on GFM;
-
mix-code with html and markdown
-
export your work with html and pdf format;
-
18 different transition animations, and you can choose single page animation well;
-
Setting one page background image different than others;
-
overview mode, multiscreen mode, remote control with socket, shark to page-flipping with ipad/iphone;
-
canvas is also supported, with socket, we sync your multiscreen in real time, and you can type some notes;
-
syntax highlighting of course, and you may want to customize your syntax highlighting style, it's supported well;
-
Animation in single page, one-step animation;
-
real time sync canvas drawing across multiple device
-
add buttons to control page-flipping
-
bugs fixed
-
sync multiscreen in real time: http://qdemo.sinaapp.com/?_multiscreen=1 (make sure alert is allowed in your browser)
-
front-end experience of mobile baidu: http://qdemo.sinaapp.com/box-fe-road.htm
-
default theme is not cool? just customize your theme! take a look with theme.moon
-
write your customize theme's template path in setting md:
title: presentation title
speaker: author name
url: http://your.site
transition: zoomin/cards/slide/...
files: /path/to/your/theme.css
# get help
nodeppt start -h
# bind given port
nodeppt start -p <port>
nodeppt start -p 8090 -d path/for/ppts
# bind host, default value: (0.0.0.0)
nodeppt start -p 8080 -d path/for/ppts -h 127.0.0.1
# socket (type 'Q' to show/hide QR Code, use your phone scan it, and you can control the slider)
# if your want to use socket, notice the follow:
* 1, make sure that your phone and your pc/mac is allowed to access to each other
* 2, the firewall
* 3, ip
nodeppt start -c socket
type 'Q' in page to show the QR Code, scan it, and you can control the slider on your phone: swipe or touch or shake to page-flipping
http://127.0.0.1:8080/md/demo.md?controller=socket
type 'Q' in page to show the QR Code, scan it, and you can control the slider on your phone: swipe or touch or shake to page-flipping
http://127.0.0.1:8080/md/demo.md?_multiscreen=1
share your awesome slider with others, why not?
npm install -g phantomjs
# start nodeppt server
nodeppt start
# export file
nodeppt pdf http://127.0.0.1:8080/md/demo.md -o a.pdf
# get generate help
nodeppt generate -h
# generate command
nodeppt generate filepath
# export all project file, include js, img, css folder
# export to publish folder default
nodeppt generate ./ppts/demo.md -a
# export to given folder
nodeppt generate ./ppts/demo.md -a -o output/path
export all ppt file and generate ppt list index:
```bash
nodeppt path -o output/path -a
nodeppt supports marked syntax, but for greater ppt, we extend the next syntax:
title: presentation title
speaker: author name
url: http://your.site
transition: zoomin/cards/slide/...
files: path/to/js/or/css/files
directory relationship:
support the followed animations:
- kontext
- vkontext
- circle
- earthquake
- cards
- glue
- stick
- move
- newspaper
- slide
- slide2
- slide3
- horizontal3d
- horizontal
- vertical3d
- zoomin
- zoomout
- pulse
if you want set single page animation, go to single page animation setting
[slide style="background-image:url('/img/bg1.png')"]
# slide with background image
## I'm subtitle
[slide]
## home page stylesheet
### ---- boundary
----
nodeppt is a ppt webapp coded by nodejs
nodeppt: https://github.com/ksky521/nodePPT
#### code formatting
the same as **Github Flavored Markdown**
<a name="transition-page"></a>
#### single page animation
on the top of the md file, you can set global transition animation in ```setting```, if want to set single page transition animation, use the followed syntax:
```markdown
[slide data-transition="vertical3d"]
## this is a vertical3d transition animation
If want to diy your ppt total, you can directly use html tag. As you see, mixed-code with html and markdown is supported well. For example:
<div class="file-setting">
<p>this is html</p>
</div>
<p id="css-demo">css style</p>
<p>for more details, visit ppts/demo.md</p>
<script>
function testScriptTag(){
}
console.log(typeof testScriptTag);
</script>
<style>
#css-demo{
color: red;
}
</style>
you can use incallback
和outcallback
to define your callback function while the page forward and backward.
suck like this:
[slide data-outcallback="outcallback" data-incallback="incallback"]
## when get into this page, call incallback function
## when left this page, call outcallback function
### css preprocessor:less\sass\stylus
---
|less| sass | stylus
:-------|:------:|-------:|--------
environment |js/nodejs | Ruby | nodejs
.ext | .less | .sass/.scss | .styl
#### insert iframe
use ```data-src``` as the url of the iframe, the iframe will not load the content untill the page be displayed.
```markdown
<iframe data-src="http://www.baidu.com" src="about:blank;"></iframe>
for more go to ppts/demo.md
title: nodeppt markdown presentation
speaker: Theo Wang
url: https://github.com/ksky521/nodePPT
transition: zoomin
[slide]
# cover style
## h1 for cover, h2 for others
[slide style="background-image:url('/img/bg1.png')"]
# background iamge {:&.flexbox.vleft}
## [slide style="background-image:url('/img/bg1.png')"]
[slide]
## home page style
### ---- boundary
----
nodeppt is a ppt webapp coded by nodejs
nodeppt: https://github.com/ksky521/nodePPT
[slide]
what? want more features?
geek mode: check the source code, find nodeppt.js, and you'll find the awesome "shake to page-flipping".
check the project directory for more infomation
To see more demo, check the ppts
folder
nodeppt -h
# type -h after any command to see the help.
nodeppt start -h
- run
nodeppt start
- visit http://127.0.0.1:8080/
- online demo: http://qdemo.sinaapp.com/