介绍

兄dei,要不要考虑下请我喝杯咖啡!

微信扫码打赏哦~

zanshang

PPTShow是一款开源免费的Java生成PPT工具包。

它在任意系统上完全不依赖其他程序的情况下能够帮助用户使用代码生成PPT文件。

但是PPT生成图片、PPT生成视频功能是通过调用微软Office实现,所以仅在Windows下可用。

我们支持

  1. 在PPT中添加页面;
  2. 在页面中添加文本、图形、线段、图片;
  3. 文本支持分段落文本,支持同一行中出现多种样式的文本;
  4. 支持背景音乐;
  5. 支持PPT页面背景样式设置;
  6. 支持元素和页面动画,元素动画支持顺序调整和时刻设置;
  7. 支持常见的元素样式设置;
  8. 在Windows环境下支持PPT转视频和PPT转图片(请确保已经安装并激活微软Office)

我们不支持

  1. 只能生成pptx文件,不支持生成ppt文件

  2. 不推荐使用PPTShow读取PPT文件(读取目前还处于demo状态,不适合生产环境使用)

  3. 暂不支持表格元素

TODO

我们目前计划中还未开发的有:

  1. 表格元素支持
  2. 嵌入字体支持

常见问题

Q:是否可以用于商业用途?

A:PPTShow遵循 Apache License 2.0 开源协议允许使用者用于包括但不限于商业使用、个人学习使用的使用用途

Q:是否可以在Linux环境生成PPT文档?

A:支持

Q:PPT生成图片是否会出现中文乱码或者字体变默认情况?

A:不会出现,我们生成图片是调用的系统Office生成,所以无需担心类似问题

Q:是否可以设置元素动画顺序?

A:支持设置顺序,且支持同时出现、上一个动画完成后出现等常见的操作

Q:PPTShow是否保证可用性或者对因代码问题导致的损失负责?

A:PPTShow不对项目进行可用性保证,也不对任何损失负责,请开发者使用前自行测试功能

快速开始

本教程会引导您通过Java代码生成一个包含HelloWorld的PPT文件

引入Jar

您可以通过maven或者手动导入的方式引入jar包

Maven坐标【推荐】
<dependency>
  <groupId>cc.pptshow</groupId>
  <artifactId>pptshow</artifactId>
  <version>1.3</version>
</dependency>
下载并手动导入【不推荐】

下载地址:https://s01.oss.sonatype.org/service/local/repositories/releases/content/cc/pptshow/pptshow/1.3/pptshow-1.3.jar

编写代码

新建一个名为 Main 的 Java class 文件,

将下面的代码拷贝到项目中之后运行,

你就获得了包含HelloWorld的PPT文件!

import cc.pptshow.ppt.domain.*;
import cc.pptshow.ppt.element.impl.*;
import cc.pptshow.ppt.show.PPTShow;
import cc.pptshow.ppt.show.PPTShowSide;

public class Main {

   public static void main(String[] args) {
       //新建一个PPT对象
       PPTShow pptShow = PPTShow.build();
       //新建一页PPT
       PPTShowSide side = PPTShowSide.build();
       
       //创建一个行内文本对象,文字设定为Hello World
       PPTInnerText pptInnerText = PPTInnerText.build("Hello World");
       //创建一个行内文本样式对象,让文本颜色为红色
       PPTInnerTextCss pptInnerTextCss = PPTInnerTextCss.build().setColor("FF00000");
       //绑定行内文本和样式对象
       pptInnerText.setCss(pptInnerTextCss);
       
       //通过行内文本创建一个行文本对象,并通过行文本对象创建文本对象
       PPTText pptText = PPTText.build(PPTInnerLine.build(pptInnerText));
       //在PPT页面中添加文本对象
       side.add(pptText);
       //在PPT里面添加PPT页面
       pptShow.add(side);
       
       //输出到文件
       pptShow.toFile("C:/Users/qrp19/Desktop/test4.pptx");
   }

}

生成文件

如果顺利的话,您会获得类似下图的文件

helloworld

入门教程

核心思想

PPTShow不同于常见的POI等PPT生成程序,PPTShow几乎完全屏蔽了PPT本身底层的XML代码。

PPTShow认为每一个不可再分的小元素都是一个对象,不同层级的对象间互相嵌套形成了整个PPT。

比如下图所示,我们认为PPT的整体、不同页面、页面中的各种元素都是一个对象。

rumen1

每个元素对象都有一个对应的样式表对象,通过 元素对象.setCss(样式表对象) 的方式就可以实现样式的绑定。

元素对象元素含义样式表对象
PPTShowSidePPT页面PPTSideCss
PPTImgPPT图片PPTImgCss
PPTShapePPT图形PPTShapeCss
PPTLinePPT线段PPTLineCss
PPTTextPPT文本PPTTextCss
PPTInnerLinePPT文本中的段落PPTInnerLineCss
PPTInnerTextPPT文本段落中的一个样式最小单元PPTInnerTextCss

注意事项

  1. PPTShow对象使用完需要手动调用 close() 方法以删除临时文件
  2. 本项目所有元素对象和样式表对象均实现了 cloneable 接口,且均为深克隆

PPT文件对象——PPTShow

PPTShow对象代表一个PPT文件,系统会在临时目录构建有关文件的必要组成部分,并在用户指定输出的时候将拼合好的文件输出到指定的位置。

因此您必须手动执行关闭操作,以删除临时目录文件,否则临时目录文件越堆越多可能导致磁盘空间不足。

创建PPTShow

您可以通过以下两种方式创建一个PPTShow对象,它们没有任何差别。

PPTShow pptShow = PPTShow.build();
PPTShow pptShow = new PPTShow();

插入一张PPT

PPTShowSide是PPT页面对象,在后面的文档中会有提到。

插入到文档页面末尾:

void add(PPTShowSide pptShowSide)

插入到文档中间某一页:

/**
* indexId 表示要插入指定页面的索引,索引从0开始
*/
void add(PPTShowSide pptShowSide, int indexId)

生成文件

根据PPTShow内容,生成一个pptx格式的PPT文件

/**
* path 输出路径,请以.pptx结尾
*/
void toFile(String path)

关闭对象

关闭对象后缓存将被清理,被关闭的对象无法生成文件

void close()

PPT页面对象——PPTShowSide

PPT页面对象表示一个PPT的页面,一个页面中通常由很多元素组成,很多个页面组成了PPT

创建对象

您可以通过以下两种方式创建一个PPTShowSide对象,它们没有任何差别。

PPTShowSide pptShowSide = PPTShowSide.build();
PPTShowSide pptShowSide = new PPTShowSide();

添加元素

元素遵循索引小的元素在下层,索引大的元素在上层

追加一个元素

void add(PPTElement pptElement)

添加一个索引为指定id的元素

/**
* indexId 表示要插入指定页面的索引,索引从0开始
*/
void add(PPTElement pptElement, int indexId)

将List中全部元素都添加进来

void addAll(List<PPTElement> pptElements)

读取元素列表

通过Get方法读取当前元素列表信息

List<PPTElement> getElements()

修改或读取背景音乐

您可以通过 backgroundMusic 属性 来设置幻灯片的背景音乐

目前仅支持播放到幻灯片结束放映,暂时不支持指定到哪一张幻灯片结束

/**
* 背景音乐文件
*/
@Getter
@Setter
private String backgroundMusic;

设定页面自动换页

您可以通过 autoPagerTime 属性 设置当前幻灯片自动切换到下一页的时间

单位:毫秒,默认为0,表示不会自动换页

/**
* 自动换页面的时间
* 单位毫秒,默认为0表示不会自动换页
*/
@Getter
@Setter
private long autoPagerTime = 0L;

设置切换动画

您可以通过设置 pageSwitchingType 来设定幻灯片切换的动画效果

默认为切出效果(也就是没有任何样式,直接硬切换)

private PageSwitchingType pageSwitchingType = PageSwitchingType.DEFAULT;

设定值对应枚举类 PageSwitchingType

枚举类中包含了幻灯片的动作样式中文名(参数1),您可以自行对照或测试使用。

DEFAULT("切出(默认效果)", PageSwitchingType.DEFAULT_XML),
SMOOTH("平滑", PageSwitchingType.SMOOTH_XML),
FADE_OUT("淡出", PageSwitchingType.FADE_OUT_XML),
ERASE("擦除", PageSwitchingType.ERASE_XML),
SHAPE("形状", PageSwitchingType.SHAPE_XML),
DISSOLVE("溶解", PageSwitchingType.DISSOLVE_XML),
NEWS_FLASH("新闻快报", PageSwitchingType.NEWS_FLASH_XML),
SPOKES("轮辐", PageSwitchingType.SPOKES_XML),
BLIND("百叶窗", PageSwitchingType.BLIND_XML),
COMB("梳理", PageSwitchingType.COMB_XML),
TAKING("抽出", PageSwitchingType.TAKING_XML),
SEGMENTATION("分割", PageSwitchingType.SEGMENTATION_XML),
LINE("线条", PageSwitchingType.LINE_XML),
BOARD("棋盘", PageSwitchingType.BOARD_XML),
LAUNCH("推出", PageSwitchingType.LAUNCH_XML),
INSERT("插入", PageSwitchingType.INSERT_XML),
PAGE_CURLING("页面卷曲", PageSwitchingType.PAGE_CURLING_XML),
CUBE("立方体", PageSwitchingType.CUBE_XML),
BOX("框", PageSwitchingType.BOX_XML),
PLAIN("飞机", PageSwitchingType.PLAIN_XML),
OPEN_DOOR("开门", PageSwitchingType.OPEN_DOOR_XML),
STRIPPING("剥离", PageSwitchingType.STRIPPING_XML),
RANDOM("随机", PageSwitchingType.RANDOM_XML)

设置样式

PPTSideCssPPTShowSide 对应的样式表

目前只有一个属性允许用户自定义

background 背景

private Background background;

背景样式,请参考【参考文档】-【通用样式】-【background背景】

PPT图片——PPTImg

PPTImg对象表示PPT中的图片元素

创建PPTImg

您可以通过以下两种方式创建一个PPTImg对象,它们没有任何差别。

PPTImg pptImg = PPTImg.build();
PPTImg pptImg = new PPTImg();

您也可以在创建的时候指定图片,有两种方式可以创建PPTImg对象,它们没有任何差别

PPTImg pptImg = PPTImg.build(String file);
PPTImg pptImg = new PPTImg(String file);

设置图片

设置当前PPTImg对象对应的图片是什么,你可以在创建对象的时候直接指定,您也可以在创建后手动调用下面的方法指定嵌入图片路径。

支持 png、jpg、gif、svg;不支持webp格式

注意:仅支持本地文件绝对路径,不支持如http开头的在线图片信息!

PPTImg setFile(String file)

设置动画

//进场动画
private InAnimation inAnimation;
//出场动画
private OutAnimation outAnimation;

请参考【参考文档】-【通用样式】-【InAnimation进场动画】和【OutAnimation出场动画】内容进行设定

读取图片路径

获取PPTImg对象的图片路径

String getFile()

设定样式

您可以通过 css 属性来设置样式信息,接下来我们将详细讲解 PPTImgCss 属性及含义。

@Getter
@Setter
private PPTImgCss css;

PPTImgCss

PPTImg 对应的样式表对象

left

private double left;

距离页面左边距离,单位cm

top

private double top;

距离页面顶边距离,单位cm

width

private double width;

元素宽度,单位cm

height

private double height;

元素高度,单位cm

cutting

private Cutting cutting;

裁剪样式,请参考【参考文档】-【通用样式】-【Cutting裁剪】

border

private Border border;

边框样式,请参考【参考文档】-【通用样式】-【border边框】

shadow

private Shadow shadow;

边框样式,请参考【参考文档】-【通用样式】-【shadow阴影】

name

private String name = "图片";

元素名称,默认为 “图片”,正常放映PPT时看不到此信息

在设置元素动画等场景下,会在动画窗格里展示元素名称信息

在同一页幻灯片中允许出现重复name

describe

private String describe = "image";

元素描述,默认为 “image”,正常放映PPT时看不到此信息

在同一页幻灯片中允许出现重复describe

angle

private double angle;

旋转角度,指顺时针旋转角度,默认为0表示不旋转。

合法取值范围:0 ≤ angle < 360

removeColor

private String removeColor;

设置透明色,格式为16进制6字符表示的颜色值,不带 # 号,例:FFFFFF

比如白底图可以设置为白色;此属性对png图片无效

PPT图形——PPTShape

PPTShape对象表示PPT中的图形元素

创建PPTShape

您可以通过以下两种方式创建一个PPTImg对象,它们没有任何差别。

PPTShape pptShape = PPTShape.build();
PPTShape pptShape = new PPTShape();

设置动画

//进场动画
private InAnimation inAnimation;
//出场动画
private OutAnimation outAnimation;

请参考【参考文档】-【通用样式】-【InAnimation进场动画】和【OutAnimation出场动画】内容进行设定

设定样式

您可以通过 css 属性来设置样式信息,接下来我们将详细讲解 PPTImgCss 属性及含义。

@Getter
@Setter
private PPTShapeCss css;

PPTShapeCss

PPTShape 对应的样式表对象

shape

private Shape shape = new Rect();

图形形状,如果您没有做特殊设置,将默认是直角矩形。

Shape是一个抽象类,有以下图形实现了它:

shape1

Rect 直角矩形

直角矩形没有更多可供设置的参数

当且仅当设定width和height相同的时候展示为正方形

Ellipse 椭圆

椭圆形没有更多可供设置的参数

当且仅当设定width和height相同的时候展示为正圆形

RoundRect 圆角矩形

可以通过get和set方法设置圆角范围参数,允许的范围是0 - 50,表示0%-50%

private double fillet;
shape2

Parallelogram 平行四边形

可以通过get和set方法设置平行四边形的倾斜程度,允许的范围是0-100,表示0% - 100%

private double fillet;
shape3

SelfShape 自定义图形

系统未实现的图形临时解决方案,不推荐使用

/**
* 用户自己定义的一段XML
*/
private String custGeom;

用户自定义一段XML来确定图形信息,内容会直接写入文件,不会进行除非空外的任何合法性校验

left

private double left;

距离页面左边距离,单位cm

top

private double top;

距离页面顶边距离,单位cm

width

private double width;

元素宽度,单位cm

height

private double height;

元素高度,单位cm

background

private Background background;

背景样式,请参考【参考文档】-【通用样式】-【background背景】

border

private Border border;

边框样式,请参考【参考文档】-【通用样式】-【border边框】

name

private String name = "图片";

元素名称,默认为 “图形”,正常放映PPT时看不到此信息

在设置元素动画等场景下,会在动画窗格里展示元素名称信息

在同一页幻灯片中允许出现重复name

angle

private double angle;

旋转角度,指顺时针旋转角度,默认为0表示不旋转。

合法取值范围:0 ≤ angle < 360

flipX

private boolean flipX;

是否进行水平翻转,默认不进行翻转

flipY

private boolean flipY

是否进行垂直翻转,默认不进行翻转

PPT线段——PPTLine

PPTLine表示PPT中的线段元素

创建PPTLine

您可以通过以下方式创建一个PPTLine对象

PPTLine pptLine = new PPTLine();

设置动画

//进场动画
private InAnimation inAnimation;
//出场动画
private OutAnimation outAnimation;

请参考【参考文档】-【通用样式】-【InAnimation进场动画】和【OutAnimation出场动画】内容进行设定

设置动画

//进场动画
private InAnimation inAnimation;
//出场动画
private OutAnimation outAnimation;

请参考【参考文档】-【通用样式】-【InAnimation进场动画】和【OutAnimation出场动画】内容进行设定

设定样式

您可以通过 css 属性来设置样式信息,接下来我们将详细讲解 PPTImgCss 属性及含义。

@Getter
@Setter
private PPTLineCss css;

PPTLineCss

PPTLine 对应的样式表对象

left

private double left;

距离页面左边距离,单位cm

top

private double top;

距离页面顶边距离,单位cm

color

private String color = "333333";

线段颜色,16进制颜色,不带 # 号

默认为 333333

lineWidth

private double lineWidth = 0.5;

线段的宽度,单位磅,默认0.5磅

line1

width

private double width;

元素宽度,单位cm,竖线宽度必须设为0

line2

height

private double height;

元素高度,单位cm,横线高度必须设为0

type

private LineType type = LineType.LINE;

线段的方向,默认线段从左上角的顶点连接到右下角的顶点

如果需要从右上角连接到左下角,请设置参数为:LineType.TOP_RIGHT_BOTTOM_LEFT

line3

PPT文本——PPTText

PPTText表示PPT文本元素,注意是文本元素整体,而非其中的一部分,比如下图中的虚线框区域就是一个PPT文本

text1

如果我们希望在一个PPTText对象中包含不同段落,如上图效果,其中包含了两个段落,分别是:PPTShow is a free open source Java native generation of PPT toolkit.support the 2010 version of the new features of PPT , does not rely on any third-party components , Linux, Windows can be used smoothly .

其中每一个段落都是一个 PPTInnerLine 对象。

段落中还可能存在多种文本呈现样式,它们紧密挨在一起,没有换行。

比如 2010 version 和前后文本就存在差异,此时相当于一个 PPTInnerLine对象包含了三个 PPTInnerText 对象,其中第一个和第三个样式相同,第二个有加粗和红色特殊效果。(如下图所示,每个线框部分都代表一个 PPTInnerText 对象)

text2

创建PPTText

您可以通过以下方式创建一个PPTText对象,两种方式没有任何差别:

PPTText pptText = new PPTText();
PPTText pptText = PPTText.build();

您还可以在创建的时候直接绑定PPTInnerLine对象集合:

只有一个PPTInnerLine时,可以使用以下方式创建 PPTText 对象,两种方式没有任何差别:

PPTText pptText = new PPTText(PPTInnerLine line);
PPTText pptText = PPTText.build(PPTInnerLine line);

有多个的时候,可以使用以下方式创建 PPTText 对象,两种方式没有任何差别:

PPTText pptText = new PPTText(List<PPTInnerLine> lineList);
PPTText pptText = PPTText.build(List<PPTInnerLine> textList);

你还可以在创建的时候直接绑定样式文件:

PPTText pptText = new PPTText(PPTInnerLine line, PPTTextCss css);
PPTText pptText = PPTText.build(PPTInnerLine line, PPTTextCss css);
PPTText pptText = new PPTText(List<PPTInnerLine> lineList, PPTTextCss css);
PPTText pptText = PPTText.build(List<PPTInnerLine> textList, PPTTextCss css);

获取最小宽度

double findMinWidthSize()

在每一个段落都不折行的情况下,最小需要的宽度

获取最小高度

double findMinHeightSize()

获取当前宽度下,最小需要的高度值。

实际上即便是设定的样式中高度比最小高度小,文本也会自动溢出显示,不会影响展示。

获取全部文本

String findAllText()

获取文本对象所有段落、所有段落内文本中的全部文本信息。

返回信息包含换行符,可以用换行符区分段落信息,但段落内文本无法区分出来。

举例:

text3

上图 PPTText 对象调用 findAllText() 方法后会获得如下文本:

PPTShow is a free open source Java native generation of PPT toolkit.
support the 2010 version of the new features of PPT. 

添加段落

在结尾处追加一个段落:

PPTText add(PPTInnerLine text)

在结尾处追加多个段落:

PPTText addAll(Collection<PPTInnerLine> text)

您也可以直接取出段落List对象自行修改操作,支持get和set操作

@Setter
@Getter
private List<PPTInnerLine> lineList = Lists.newArrayList();

设定样式

您可以通过 css 属性来设置样式信息,接下来我们将详细讲解 PPTTextCss 属性及含义。

@Getter
@Setter
private PPTTextCss css;

PPTTextCss

PPTText 对应的样式表对象

left

private double left;

距离页面左边距离,单位:cm

top

private double top;

距离页面顶边距离,单位:cm

width

private double width;

元素宽度,单位:cm,默认为最小宽度

height

private double height;

元素高度,单位:cm,默认为最小高度

lineHeight

private double lineHeight;

行高,单位:倍行距,默认为1

background

private Background background

背景样式,请参考【参考文档】-【通用样式】-【background背景】

angle

private double angle;

旋转角度,指顺时针旋转角度,默认为0表示不旋转。

合法取值范围:0 ≤ angle < 360

name

private String name = "文本";

元素名称,默认为 “文本”,正常放映PPT时看不到此信息

在设置元素动画等场景下,会在动画窗格里展示元素名称信息

在同一页幻灯片中允许出现重复name

PPT文本中的段落——PPTInnerLine

有关 PPTTextPPTInnerLinePPTInnerText的关系,请参考PPTText的文档

创建PPTInnerLine

您可以通过以下方式创建一个PPTInnerLine对象,两种方式没有任何差别:

PPTInnerLine pptInnerLine = new PPTInnerLine();
PPTInnerLine pptInnerLine = PPTInnerLine.build();

您还可以直接快速创建空行对象:

PPTInnerLine pptInnerLine = PPTInnerLine buildEmptyLine();
/** 
* num:空几行
*/
PPTInnerLine pptInnerLine = PPTInnerLine buildEmptyLine(int num);

您还可以在创建的时候直接绑定PPTInnerText对象集合:

只有一个PPTInnerText时,可以使用以下方式创建 PPTInnerLine 对象,两种方式没有任何差别:

PPTInnerLine pptInnerLine = new PPTInnerLine(PPTInnerText text);
PPTInnerLine pptInnerLine = PPTInnerLine.build(PPTInnerText text);

有多个的时候,可以使用以下方式创建 PPTInnerLine 对象,两种方式没有任何差别:

PPTInnerLine pptInnerLine = new PPTInnerLine(List<PPTInnerText> textList);
PPTInnerLine pptInnerLine = PPTInnerLine.build(List<PPTInnerText> textList);

你还可以在创建的时候直接绑定样式文件:有任何差别:

PPTInnerLine pptInnerLine = new PPTInnerLine(PPTInnerText text, PPTInnerLineCss css);
PPTInnerLine pptInnerLine = PPTInnerLine.build(PPTInnerText text, PPTInnerLineCss css);
PPTInnerLine pptInnerLine = new PPTInnerLine(List<PPTInnerText> textList, PPTInnerLineCss css);
PPTInnerLine pptInnerLine = PPTInnerLine.build(List<PPTInnerText> textList, PPTInnerLineCss css);

添加段内文本

在结尾处追加一个段落:

PPTInnerLine add(PPTInnerText text)

在结尾处追加多个段落:

PPTInnerLine addAll(Collection<PPTInnerText> text)

您也可以直接取出段落List对象自行修改操作,支持get和set操作

@Setter
@Getter
private List<PPTInnerText> textList = Lists.newArrayList();

设定样式

您可以通过 css 属性来设置样式信息,接下来我们将详细讲解 PPTInnerLineCss 属性及含义。

@Getter
@Setter
private PPTInnerLineCss css;

PPTInnerLineCss

PPTInnerLine 对应的样式表对象

lineHeight

private double lineHeight;

行高,单位:倍行距,默认为1

align

private String align = PPTNameConstant.ALIGN_LEFT;

对齐方式,存在以下对齐方式

  • PPTNameConstant.ALIGN_LEFT 左对齐
  • PPTNameConstant.ALIGN_RIGHT 右对齐
  • PPTNameConstant.ALIGN_CENTER 居中对齐
  • PPTNameConstant.ALIGN_JUST 两端对齐
  • PPTNameConstant.ALIGN_DIST 分散对齐

五种类型对应下图画圈的部分,图中从左到右顺序即为上方顺序

text4

特别说明

实际上每一行都有一个end对象,用户可以get或者set:

private PPTInnerTextEnd end

它表示行尾信息,我们十分不推荐使用者自定设定有关参数,系统会自动添加行尾对象。

如果您不完全明白其中参数含义,请不要手动修改,如果认为当前有功能无法实现推荐提issues解决!

PPT文本段落中的一个样式最小单元——PPTInnerText

有关 PPTTextPPTInnerLinePPTInnerText的关系,请参考PPTText的文档

创建PPTInnerText

您可以通过以下方式创建一个PPTInnerText对象,两种方式没有任何差别:

PPTInnerText pptInnerText = new PPTInnerText();
PPTInnerText pptInnerText = PPTInnerText.build();

您还可以直接创建对象同时设置文本信息:

PPTInnerText pptInnerText = new PPTInnerText(String text);
PPTInnerText pptInnerText = PPTInnerText.build(String text);

您还可以同时再设置样式表:

PPTInnerText pptInnerText = new PPTInnerText(String text, PPTInnerTextCss pptInnerTextCss);
PPPTInnerText pptInnerText = PPTInnerText.build(String text, PPTInnerTextCss pptInnerTextCss);

设置文本

您可以通过 text 属性设置或读取文本的内容,支持Get和Set方法

@Setter
@Getter
private String text = null;

设定样式

您可以通过 css 属性来设置样式信息,接下来我们将详细讲解 PPTInnerTextCss 属性及含义。

@Setter
@Getter
private PPTInnerTextCss css = new PPTInnerTextCss();

PPTInnerTextCss

PPTInnerText 对应的样式表对象

fontSize

private int fontSize = 18;

字体大小,默认为18

和WPS、Ms Office里面的字号是一样的

itext1

spacing

private double spacing = 0;

字符间距,默认为0,表示默认

改为负值后文字更加紧凑,改为正值后文字更加宽松

fontFamily

private String fontFamily = "宋体";

字体,如果电脑里面没有这个字体即便设置了也无法正常显示

建议使用前先读取系统中有哪些字体

另外有部分字体存在多个个人或机构打包,可能导致一套字体拥有不同的名称(如:思源系列字体),请留意类似情况!

color

private String color = "000000";

文本颜色,16进制颜色码,不带#号。默认为黑色

italic

private boolean italic;

是否文字倾斜,默认不倾斜。为true时倾斜展示。

bold

private boolean bold;

是否文本加粗显示,默认不加粗,为true时加粗展示。

裁剪——Cutting

Cutting对象表示对元素进行剪裁,形成指定的形状

创建Cutting

您可以通过以下两种方式创建一个Cutting对象,它们没有任何差别。

Cutting cutting = Cutting.build();
Cutting cutting = new Cutting();

left

private double left;

剪切掉左侧部分的百分比 0-100

top

private double top;

剪切掉顶侧部分的百分比 0-100

private double right;

剪切掉右侧部分的百分比 0-100

bottom

private double bottom;

剪切掉底侧部分的百分比 0-100

cutShape

您可以通过 cutShape 属性来设置裁剪的形状

默认为直角矩形

private CutShape cutShape = new RectCutShape();

有以下类实现了CutShape:

RoundRectCutShape 圆角矩形裁剪

private double fillet;

圆角比例,最小值是0最大值是50

因为一个叫弯曲50%长度了,两个角加一块就已经100%了

EllipseCutShape 椭圆裁剪

椭圆裁剪不支持自定义参数

RectCutShape 直角矩形裁剪

直角矩形裁剪不支持自定义参数

边框——Border

Border对象表示边框,是一个抽象类,使用的时候请使用下面的颜色边框或者渐变边框类

ColorBorder 颜色边框

单一颜色边框对象,您可以通过new方法创建一个ColorBorder对象

Color 颜色

private String color = "000000";

设定颜色,16位颜色信息,不包含 # ,默认为黑色

width 宽度

private double width = 1.0;

设定宽度,单位是磅,默认为1.0

GradientBorder 渐变边框

边框宽度固定,颜色渐变的场景

width 宽度

private double width = 1.0;

设定宽度,单位是磅,默认为1.0

gradientDirection 角度

private double gradientDirection = 90;

设定角度,默认为90度,角度效果请参考WPS或者微软Office中渐变角度和颜色的效果

gradients 渐变色列表

private List<Gradient> gradients = Lists.newArrayList();

存储渐变色对象,请参考【参考文档】-【通用样式】-【Gradient渐变】查看此对象设置方法

阴影——Shadow

Shadow对象表示阴影,是新版本ppt才有的一个功能

Color 颜色

private String color = "000000";

设定颜色,16位颜色信息,不包含 # ,默认为黑色

alpha 透明度

private double alpha = 0;

设定透明度,数值越大越透明,默认是0,不透明

sizeX 横向大小

private double sizeX = 100;

阴影横向大小,百分比形式,默认和原始元素大小一致

sizeY 纵向大小

private double sizeY = 100;

阴影纵向大小,百分比形式,默认和原始元素大小一致

distance 距离

private double distance = 5;

设定距离,单位是磅,默认是5磅

blur 模糊

private double blur = 10;

边缘模糊程度,单位是磅,默认是10磅

angle 角度

private double angle = 0;

阴影投射角度,默认是0

背景——Background

Background是一个抽象类,表示元素的背景,使用时请使用它的实现类

ColorBackGround 纯色背景

表示某一个颜色的单色背景

color 颜色

private String color;

16禁止颜色值,不带#号,无默认值

alpha 透明度

private Double alpha;

支持数值 0 - 100,数字越大越透明,默认不透明

ImgBackground 图片背景

表示使用一个图片作为背景

img 图片

private String img;

图片路径,支持png、jpg、gif

图片会被强制拉伸,建议提前根据元素大小进行裁剪

GradientBackground 渐变背景

表示以多种颜色渐变的形式作为元素的背景

gradientDirection 渐变角度

private Double gradientDirection;

支持0-360,默认角度为0

gradients 渐变色列表

private List<Gradient> gradients = Lists.newArrayList();

存储渐变色对象,请参考【参考文档】-【通用样式】-【Gradient渐变】查看此对象设置方法

渐变节点——Gradient

Gradient对象表示渐变过程的某一个渐变节点,系统会根据相邻的两个渐变节点的属性补全中间的颜色过渡,形成渐变效果

Color 颜色

private String color;

颜色信息,16进制的颜色值信息,不带#号

proportion

private double proportion;

占比位置,取值范围:0-100

alpha

private Double alpha;

透明度,取值范围::0-100,数字越大越透明

lum

private Double lum;

亮度,0-100,数字越大越暗

进场动画——InAnimation

InAnimation表示进场动画,也被称为出现动画。

所有AnimationElement的子类都拥有进场和出场动画属性。

private InAnimation inAnimation;

您可以通过Set或者Get方法对此内容进行修改或读取

默认值为null,即没有动画。

以下是InAnimation包含的属性:

showAnimationType 展示时间

private ShowAnimationType showAnimationType = ShowAnimationType.SAME_TIME;

这个属性设置的是动画出现时间,允许的枚举值有以下三种:

  • ShowAnimationType.SAME_TIME 同时出现(默认)
  • ShowAnimationType.CLICK 单击出现
  • ShowAnimationType.AFTER 在上一动画完成后出现

inAnimationType 入场动画效果

private InAnimationType inAnimationType;

默认是null

如果您不希望有动画请不要在这里设置成null,而是直接把文档开头提到的inAnimation设置为null

属性是一个枚举类,目前支持以下效果:

InAnimationType.BLINDS,//百叶窗
InAnimationType.WIPE,//擦除
InAnimationType.WHEEL,//轮子
InAnimationType.SPLITTING,//劈裂
InAnimationType.BOARD,//棋盘
InAnimationType.LINE,//随机线条
InAnimationType.ZOOM//缩放

InAnimationType 枚举类中包含了中文名称和默认持续时间,可以供您参考。

不在以上列表中的样式不建议使用

animationAttribute 属性信息

private AnimationAttribute animationAttribute;

属性信息,是枚举类,在一些动画效果中允许出现一些属性,您可以根据需要进行设定

但请务必保证您设置的属性是这个动作中允许被设置的,如果您设置了一个不属于此动作的属性将会自动恢复为默认。

动画效果和属性对应关系可以参考WPS或Office里面的动画设置窗口

in1

timeMs 持续时长毫秒

private Integer timeMs;

持续时长,单位是毫秒。每一个动画都包含默认持续时长。默认持续时长和Office中此动作的默认持续时长是一致的,如果想和Office保持一致的话一般不需要填写。

在Office或者WPS等阅读器中,设定为以下毫秒时长会展示为指定的语义文本。推荐您从以下的数值中选择:

时长标识
500非常快
1000快速
2000中速
3000慢速
5000非常慢

出场动画——OutAnimation

OutAnimation表示进场动画,也被称为出现动画。

所有AnimationElement的子类都拥有进场和出场动画属性。

private OutAnimation outAnimation;

您可以通过Set或者Get方法对此内容进行修改或读取

默认值为null,即没有动画。

暂时不支持设置出场动画,预计在后续版本中将被支持!

PPT工具——PPTUtil类

PPT转MP4文件

static synchronized void PPT2MP4(String pptPath, String mp4Path)

pptPath:PPT文件路径

mp4Path:需要生成的mp4文件路径

目前存在两个PPT同时生成视频vbs脚本无法支持的问题,所以新版本强行加了一个锁,目前待解决。

注意:

  1. 系统必须已经安装并激活微软的Office
  2. 仅限Windows系统
  3. 生成过程可能存在Office软件出现异常导致无法转换的可能

压缩MP4文件

static void mp4Compression(String bigMp4Path, String smallMp4Path)

bigMp4Path:PPT2MP4方法生成的MP4文件

smallMp4Path:缩小后的文件储存路径,.mp4结尾,不支持覆盖写入,必须此路径不存在文件

压缩生成的MP4文件,自动压缩为1280x720大小15帧的视频,一般25页PPT视频压缩后在20MB左右

注意:

1. 必须电脑安装了ffmeng,且添加了环境变量
1. 暂不支持调整参数

PPT转PNG图片

static void PPT2PNG(String pptPath, String pngPath)

pptPath:PPT文件路径

pngPath:生成图片存储路径

调用此方法会生成一个文件夹,文件夹里面每张PPT生成一张图片

PPT拼长图

static void png2LongImg(String pngPath, String longImgPath, String waterImgPath)

pngPath:PPT2PNG方法生成的图片文件夹路径,不能包含其他非本次生成的图片文件,否则会出错

longImgPath:长图存储地址,.jpg结尾

waterImgPath:水印文件,会随机贴在长图上,暂时不支持无水印生成

生成如下效果图片:

0010d75d-368f-4a81-bbca-e0a9fb8039f3

如果总页数是双数,小图第一个会出现首页;如果总页数是单数,小图第一个不会出现首页。

是否是Windows电脑

static boolean isWindows()

因为好几个方法只支持Windows电脑,建议在调用前进行判断。

如果非Windows电脑调用上面几个仅限Windows电脑可用的方法,会直接抛出异常。

关于

项目名称:PPTShow

Git代码地址:(欢迎点个Star呀!)

pptshow在Gitee

项目官网:PPTShow官网

提交issues:Gitee中文提交

查看使用协议:Apache License 2.0


开发者:beihem

联系我:qiruipeng@88.com