精益求精, ePub 电子书制作手记

时间:2022-02-23 21:05:54

什么是 ePub


  ePub 是 Electronic Publication 的缩写,意为电子出版,是一个*的开放标准,属于一种可以“自动重新编排”的内容,也就是文字内容可以根据阅读设备的特性,以最适于阅读的方式显示。ePub 档案内部使用了 XHTML 或 DTBook (一种由DAISY Consortium提出的XML标准)来展现文字、并以 .zip 压缩格式来包裹档案内容。ePub 格式中包含了数位版权管理(DRM)相关功能可供选用。

ePub 格式的优势


  说白了,ePub 就是一个把书籍内容包含在内的压缩包,解压后的文件一般包含 CSS(样式表文件)、HTML(章节内容文件)、JPG(插图)、TFF(内嵌字体文件)。

  • ePub 中的所有内容基本上都是XML。ePub 文件可使用标准 XML 工具创建,不需要任何专门或者私有的软件。
  • ePub 内容(eBook 的具体内容)基本上都是 XHTML 1.1 。
  • 大多数 ePub XML 模式都来自现成的、可免费获得的、已发布的规范。 最关键的在于 ePub 元数据是 XML,ePub 内容是 XHTML。如果您的文档构建系统产生的结果用于 Web 或基于 XML,那么也可用于生成 ePub。

ePub 基本架构


精益求精, ePub 电子书制作手记

精益求精, ePub 电子书制作手记

精益求精, ePub 电子书制作手记

精益求精, ePub 电子书制作手记

精益求精, ePub 电子书制作手记

精益求精, ePub 电子书制作手记

精益求精, ePub 电子书制作手记

更多的详细介绍可以参考《ePub OPF 電子出版品結構資料 中文規範書v1.0》

ePub 电子书制作,走起!


  子曰:“工欲善其事,必先利其器。”制作电子书也是如此,想要制作出质量上乘的电子书就必须得有利器的协助,Jutoh 和 Sigil 便是这两把利器,这两者就好比倚天剑和屠龙刀,刀剑合璧,天下归心。当然光有刀剑可不行,没有鞘来装盛的武器可是会伤及自身的,Word 就是这么一把鞘。

  得到了这三样至宝,就得学会怎样使用。一般来说,电子书的制作分一下几个流程:

  1. 用 Word 标记样式;
  2. 将 Word 文件导入到 Jutoh 中,进行章节分割,并设计封面、目录,编译生成 ePub 电子书
  3. 使用 Sigil 对 ePub 电子书进行调整
  4. 使用 Calibre 将 ePub 格式转换成 mobi、azw3 等格式(如果需要内嵌字体,则在这之前,可以先使用 FontRepack 嵌入字体)。

  怎么使用 Word 就不必我一一赘述了,但要想制作精美的电子书还得需要好的样式模板,你可以根据自己的爱好定制模板,也可以使用现成的模板

  这里对『样式模板』做一个简单的说明(详细说明可以参考这个帖子):

  常用的样式大致分三种:段落样式、字符样式(或者叫行内样式)、链接样式。

  顾名思义,段落样式管这一段长什么样,字符样式只针对特定的字符,链接样式有点特别,你把它用在段落上就像段落样式,用在字符上就像字符样式。一般很少用链接样式,除了标题系列。

  通过模板规范导入的文本后,你就得到了一个已经完成的 Word 文件,下面打开 Jutoh,新建一个项目并导入这个 Word 文件。

精益求精, ePub 电子书制作手记

  通过 Jutoh,你可以完成:

  • 制作电子书的目录
  • 完善电子书的元数据
  • 给电子书增加封面
  • 编译成 ePub 格式的电子书
  • ……

  上一步中编译出来的 ePub 其实就已经可以供人阅读了,如果你对电子书有更高的要求,可以使用 Sigil 给电子书进行调整、增加富文本。

  • Sigil 编辑元数据:

精益求精, ePub 电子书制作手记

  • Sigil 让多看全屏显示封面

在 content.opf 里的下把需要全屏显示的页后面都加上“properties=”duokan-page-fullscreen”

精益求精, ePub 电子书制作手记

  • 首行缩进与段落间距

style.css 中使用 text-indent 来控制行首缩进
text-indent: 2em; 的意思就是行首缩进 2 个字符

精益求精, ePub 电子书制作手记

用 margin 控制段落间距

 .p {
margin-top: 0.00em;
margin-bottom: 0.00em;
margin-left: 0.00em;
margin-right: 0.00em;
}

你还可以这样写:

.p {margin: 0em 0em 0em 0em;}
  • 注:单位 em 是字符的意思,px 是像素。

其他比较常见的 CSS 代码这里举个例子:

.head {
font-weight: bold;
/*加粗*/
font-size:1.5em;
/*字号*/
color: #985C00;
/*字体颜色*/
line-height:130%;
/*行高*/
text-decoration:underline;
/*下划线*/
text-align: right;
/*右对其*/
text-indent: 0.00em;
/*首行缩进*/
adobe-hyphenate: none; hyphens: none; -moz-hyphens: none; -webkit-hyphens: none;
/*分割线*/
margin-top: 0.00em;
/*外边距-上*/
margin-left: 0.00em;
/*外边距-左*/
margin-right: 0.00em;
/*外边距-右*/
margin-bottom:0.5em;
/*外边距-下*/
padding: 5px 5px 5px 5px;
/*内边距*/
border-width: 0.1em;
/*设置四条边框的宽度*/
}
你还可以参考《CSS参考手册》

富文本,大显神通


用过 Kindle 的童鞋都知道,Kindle 阅读电子书有个弹窗注释的功能,这个弹窗注释,就是富文本的一种。

由于注释一般需要上标,类似这样的一段文字:

后世将李白[1]和杜甫并成为“李杜” 。

STEP 1)所以需要在 style.css 中添加上这么一段代码:

.footnote {
text-align: justify;
text-indent: 0em;
line-height: 110%;
font-size: 0.85em;
font-family: "zw","宋体","明体","明朝",serif;
}

STEP 2)然后在需要注释的地方插入如下代码:

<a id="ref_footnotebookmark_start_1_1"></a><span style=" font-size: 0.75em; vertical-align: super;"><a href="#ref_footnotebookmark_end_1_1">[1]</a></span>

那么文本就变成这样了:

后世将李白<a id="ref_footnotebookmark_start_1_1"></a><span style=" font-size: 0.75em; vertical-align: super;"><a href="#ref_footnotebookmark_end_1_1">[1]</a></span>和杜甫并成为“李杜” 。

红色部分:声明一个 ID,ID 的名称是"ref_footnotebookmark_start_1_1"

绿色部分:规定紫色部分的样式

蓝色部分:跳转到另一个 ID,ID 的名称是"ref_footnotebookmark_end_1_1","#"是指向的意思。

紫色部分:显示的上标

STEP 3)在章节的末尾插入如下代码

<p class="footnote" id="ref_footnotebookmark_end_1_1"><span style=" font-size: 0.75em; vertical-align: super;"><a href="#ref_footnotebookmark_start_9_1">[1]</a></span>李白,字太白,号青莲居士。</p>

很遗憾的是,多看并不支持这种代码,它另有一种规范。

STEP 1)在 style.css 中插入如下代码:

 /** Duokan Extent Start **/
sup img {
line-height: 1.2;
width: 1em;
height: 1em;
margin:;
padding: 0em;
vertical-align: text-top;
} li.duokan-footnote-item {
font-family:"ht","微软雅黑","黑体","zw",sans-serif;
text-align: left;
font-size: small;
line-height: 1.2;
padding: 0px;
}
/** Duokan Extent End **/

STEP 2)注释需要一张15x15的图片代替上标显示,你可以使用这个精益求精, ePub 电子书制作手记也可以自己制作一张。

STEP 3)在 Sigil 中将这个图片添加到 Images 文件夹内,命名为 note.png

STEP 4)在需要注释的地方插入如下代码:

<sup><a class="duokan-footnote" href="#ref_footnotebookmark_end_1_1" id="ref_footnotebookmark_start_1_1"><img alt="" src="../Images/note.png" /></a></sup>

那么段落变成这个样子:

后世将李白<sup><a class="duokan-footnote" href="#ref_footnotebookmark_end_1_1" id="ref_footnotebookmark_start_1_1"><img alt="" src="../Images/note.png" /></a></sup>和杜甫并成为“李杜” 。

STEP 5)在章节末尾添加脚注代码:

 <ol class="duokan-footnote-content">
<li class="duokan-footnote-item" id="ref_footnotebookmark_end_1_1">
<a href="#ref_footnotebookmark_start_1_1">这里是注释</a>
</li>
</ol>

如果有多个注释可以这样写:

 <ol class="duokan-footnote-content">

 <li class="duokan-footnote-item" id="ref_footnotebookmark_end_1_1">
<a href="#ref_footnotebookmark_start_1_1">注释一</a>
</li> <li class="duokan-footnote-item" id="ref_footnotebookmark_end_1_2">
<a href="#ref_footnotebookmark_start_1_2">注释二</a>
</li> <li class="duokan-footnote-item" id="ref_footnotebookmark_end_1_3">
<a href="#ref_footnotebookmark_start_1_3">注释三</a>
</li> </ol>
更多信息可参阅《 多看电子书规范扩展开放计划》

-----------------The END------------------