tcolorbox 宏包简明教程
嗯,我消失好几天了。那么,我都在做什么呢?没错,就是写这篇文章了。这篇文章写起来着实有些费神了。于是,如果你觉得这篇文章对你有帮助,不妨扫描文末的二维码,适量赞助一下哦~!
tcolorbox 宏包是 Thomas F. Sturm 开发的一个用于绘制彩色文本框的宏包。tcolorbox 底层基于 pgf,功能也是十分强大。
一个月前,有群友在群里问到如何制作下面这样的蓝色边框,于是这里借着实现这一边框的时机,简单讲讲 tcolorbox 的用法。
概述:安装与调用
和大多数宏包一样,tcolorbox 被 MiKTeX 和 TeX Live 都收录其中。因此,通常情况,你只需要用相应的宏包管理器安装就好。
使用起来,也很简单。和其他宏包一样,你需要在导言区,使用 \usepackage 命令调用这个宏包。
1 |
\usepackage{tcolorbox}
|
你可以在调用宏包时,用可选参数指明需要加载哪些程序库;也可以在调用 tcolorbox 之后,显式地使用 \tcbuselibrary 来调用 tcolorbox 提供的丰富程序库。比如,下面的代码调用了 skins, breakable, theorems 三个程序库。
1 |
\usepackage{tcolorbox}
|
每个程序库,都对应着一个 tcbXXX.code.tex 文件。实际上,使用 \tcbuselibrary 命令,就是调用了一个个这样的文件。以下是常见可用的 tcolorbox 程序库:
skins: 调用tikz宏包,提供丰富的文本框样式;vignette: 提供一些装饰性的样式;raster: 用以调整若干tcolorbox的排布样式listings/listingsutf8/minted: 用以和对应的宏包联用,实现好看的代码清单theorems: 用以生成定理类环境breakable: 实现自动分页的文本框magazine: 实现类似杂志的分段文本fitting: 实现字体大小和文本框大小的自适应
tcolorbox 基础
基础环境和基础命令
tcolorbox 宏包提供了与宏包同名的环境,是整个宏包的基础环境,用于生成段落间的文本框。与之对应,宏包还提供了 \tcbox 命令,用于生成行内的文本框。
1 |
\begin{tcolorbox}[⟨options⟩]
|
tcolorbox 环境和 \tcbox 命令都可以接收一组选项,用来控制文本框的样式。我们来看看下面的代码,及其相应的效果。
tcb-basic.tex
1 |
\documentclass{article}
|

7 – 9 行是一个最朴素的 tcolorbox 环境。我们看到,在默认情况下,tcolorbox 输出了一个深灰色圆角边框、浅灰底色的文本框。
11 – 15 行则在上述最朴素的 tcolorbox 环境的基础上,增加了一条虚线。这条虚线由 \tcblower 控制,它将 tcolorbox 中的内容分成了上下两部分。
17 – 21 行则第一次指定了 tcolorbox 环境的选项。tcolorbox 环境和 \tcbox 都可以接受一串 key-value 的参数列表。这里,我们给 tcolorbox 环境传入了一个名为 title 的参数,它的值是 I Love Sophia。顾名思义,这给 tcolorbox 输出的文本框起了一个名字。默认情况下,这个名字会显示在文本框的头部。
23 – 25 行引入了一个新的命令——\tcbset。显而易见,tcb 是宏包名字的缩写,而 set 自然是「设置」的意思。\tcbset 也可以接受一串 key-value 参数列表,这些参数将对(同一个分组内) \tcbset 之后的所有 tcbcolorbox 环境和 \tcbox 命令生效。这里引入了一些参数,我们在此不深究它们的含义,且先看效果再说。
在 27 行,我们遇到了第一个 \tcbox 命令。在先前 \tcbset 设置的选项之外,这个 \tcbox 还显式地引入了 tcbox raise base 这一参数。结合效果,不难猜出这个选项调整了 \tcbox 生成盒子的基线(baseline)。
29 行和 40 行开头的两个 \tcbox 命令,一方面说明 tcolorbox 宏包提供了相当多的控制选项,因此文本框的样式是高度可定制的;另一方面说明了 \tcbox 内里可以装各种类型的文本——包括表格和图档。
定义和重定义新的 box
tcolorbox 宏包提供了 4 个命令,分别用来定义和重定义 tcolorbox 环境和 \tcbox 命令制作的文本框样式。
1 |
\newtcolorbox[⟨init options⟩]{⟨name⟩}[⟨number⟩][⟨default⟩]{⟨options⟩}
|
\newtcolorbox 类似 LaTeX 的 \newenvironment 命令,能够基于 tcolorbox 环境创建一个新的 box 环境;\renewcolorbox 则类似 LaTeX 的 \renewenvironment。\newtcbox 类似 LaTeX 的 \newcommand 命令,能够基于 \tcbox 命令创建一个新的 box 命令;\renewtcbox 则类似 LaTeX 的 \renewcommand 命令。
在这里
⟨init options⟩通常是用来控制计数器的,具体可以参见tcolorbox宏包说明手册的第 5 章⟨name⟩是环境或命令的名字⟨number⟩是环境或命令参数的个数⟨default⟩是环境或命令可选参数的默认值⟨options⟩接受类似\tcbset的 key-value 参数列表
tcb-env.tex
1 |
\documentclass{article}
|

这里,在 5 – 7 行,我们用 \newtcolorbox 定义了名为 mybox 的环境;在 9 – 12 行,我们用 \renewtcolorbox 重新定义了名为 mybox 的环境;14 – 16 行则用原始的 tcolorbox 重复实现了 mybox 环境的效果。
tcb-env-complex.tex
1 |
\documentclass{article}
|

在这里,我们用 \newtcolorbox 命令定义了一个稍微复杂的 mybox 环境。它接收两个参数,其中第一个参数是可选的,默认值为空;第二个参数则是必填的参数。第一个参数用作 tcolorbox 环境参数补充,第二个参数则是 box 的标题。另外值得注意的是,代码中引入了 most 这个程序库。most 会自动调取除 minted 和 documentation 之外所有的 tcolorbox 程序库。
tcb-command.tex
1 |
\documentclass{article}
|

这里我们用 \newtcbox 命令定义了一个新的 \mybox 命令,它可以用来高亮选中的单词。
warp 既有环境
有的时候,我们希望将既有的 LaTeX 环境改造成带文本框样式的环境。这时候,可以使用 \tcolorboxenvironment环境。它的用法是
1 |
\tcolorboxenvironment{⟨name⟩}{⟨options⟩}
|
tex-env-redefine.tex
1 |
\documentclass{article}
|

在这里,我们用 \tcolorboxenvironment 命令,在 myitemize 环境外重新 wrap 了一层。新的 myitemize 环境在左侧有一道宽为 3mm 的红色提示线。不难发现,\tcolorboxenvironment 命令可以在(几乎)不改变原有环境效果的情况下,定义一个新的文本框环境。这种功能十分实用。
常用选项
这里列一些常用的选项,用来控制 tcolorbox 环境和 \tcbox 命令的效果。其它未尽选项和效果,可以查看 tcolorbox 的说明手册。
标题的内容控制
title: 设置标题内容,默认为空。adjusted title: 设置标题内容,默认为空。使用title生成的标题,标题栏会根据标题内容的高低自动调整;而使用adjusted title生成的标题,标题栏的高度由当前行文本框中,标题占据高度最高的文本框决定。squeezed title: 设置标题内容,默认为空。使用squeezed title生成的标题,如果超过允许的长度,不会换行,而是会在横向进行压缩。squeezed title*: 设置标题内容,默认为空。合并了adjusted title和squeezed title的效果。
tcb-titles.tex
1 |
\documentclass{article}
|

我们看到,两组红色的文本框,它们的标题分别由 title 和 squeezed title 指定。因此,标题占据的高度会随着标题本身的高度变化。两组蓝色的文本框,它们的标题则分别由 adjusted title 和 squeezed title* 指定。于是,标题占据的高度,会根据所处同一行的文本框中,标题所需高度最高的那个文本框来确定,看起来,就整齐多了。
后面两组文本框,他们的标题分别由 squeezed title 和 squeezed title* 指定。我们发现,当标题长度过长时,标题在水平方向上会被压缩。
标题位置
默认情况下,文本框的标题会附在文本框的上方。这一状态称为 attach。我们也可以将标题从默认位置上移开,这个动作称为 detach。detach 之后,我们就可以用 tcolorbox 提供的宏,将标题放在任意自己想要放的位置。其中,\tcbtitletext 储存了标题的文本内容,\tcbtitle 则储存了标题的文本及样式。
attach title: 默认样式,标题将显示在文本框上方的单独单元格里。detach title: 取消文本框上方单独的单元格,标题需要用户手工指定位置。attach title to upper = ⟨text⟩: 取消文本框上方单独的单元格,标题放在文本框 upper 部分的头部。
tcb-title-pos.tex
1 |
\documentclass{article}
|

在这里,6 – 8 行是正常的情形;9 – 11 行是 detach 的情形,然后用 before upper 将 \tcbtitle 放在 upper 部分之前;12 – 14 行也是 detach 的情形,然后用 after upper 将 \tcbtitle 换行后放在 upper 部分的末尾;16 – 18 行和 19 – 21 行,都是 attach title to upper 的情形,前者直接给 attach title to upper 传入了标题后的分隔符,后者则使用 after title 传入分隔符——这两种方式的效果是一致的。
upper 和 lower 的状态
tcolorbox 宏包输出的文本框,在逻辑上可以分为 upper 和 lower 两个部分,在代码中用 \tcblower 命令分割 upper 和 lower 两部分——如果没有 \tcblower,则当前文本框只有 upper 部分,而没有 lower 部分。
upper 和 lower 部分都有可见 (visible) 和不可见 (invisible) 两种状态,lower 部分还有被忽略 (ignored) 这一额外的状态。
upperbox = ⟨visible|invisible⟩: 控制 upper 部分是否可见lowerbox = ⟨visible|invisible|ignored⟩: 控制 lower 部分是否可见visible: 同时控制 upper 和 lower 部分可见invisible: 同时控制 upper 和 lower 部分不可见
下面的代码很容易理解,就不做详细解释了。
tcb-visible.tex
1 |
\documentclass{article}
|

upper 和 lower 部分的分隔
默认情况下,upper 和 lower 部分之间会有一个分隔,不过,我们也可以通过 lower separated 来控制是否显示这一分隔符。
lower separated = ⟨true|false⟩: 控制是否显示 upper 和 lower 两部分中间的分隔。
tcb-lower-separated.tex
1 |
\documentclass{article}
|

这里用 tcbraster 环境做了一个明显的左右对比。我们可以看到,当开启 lower separated=false 时,各个 skin 下的分隔都不见了。值得注意的是,中间一行中,我们使用了 sidebyside 选项,它能将 upper 和 lower 两个部分从上下的布局样式,改变成左右的布局样式。
颜色和字体控制
tcolorbox 提供了很多颜色控制选项,用来控制文本框各个部分的颜色效果。
colframe: 文本框框沿的颜色,默认是black!75!white。colback: 文本框内的底色,默认是black!5!white。colbacktitle: 文本框中标题框的底色,默认是black!50!white。colupper: upper 部分文字的颜色。collower: lower 部分文字的颜色。coltext: 同时设置 upper 和 lower 部分文字的颜色。coltitle: title 部分文字的颜色。
tcb-color.tex
1 |
\documentclass{article}
|

fontupper: 控制 upper 部分的字体fontlower: 控制 lower 部分的字体fonttitle: 控制 title 部分的字体
tcb-font.tex
1 |
\documentclass{article}
|

宽度控制
tcolorbox 宏包提供了三个选项对宽度进行最基本的控制,它们分别是:
width: 文本框的总宽度,默认是\linewidth。textwidth: 文本框内文本的宽度。add to width: 在现有设置的基础上,调整文本框的总宽度。
tcb-width.tex
1 |
\documentclass{article}
|

这里,我们首先将 width 设置为 5cm,然后将 text width 设置为 5cm,最后将 width 在 5cm 的基础上,用 add to width 减去 1cm。
线条
tcolorbox 输出的文本框,其框线都可以设置宽度。
toprule/bottomrule/leftrule/rightrule: 分别设置文本框上、下、左、右的框线宽度。titlerule: 设置标题框和内容框之间的框线宽度。boxrule: 一口气设置上述 5 条框线的宽度。
tcb-rule.tex
1 |
\documentclass{article}
|

这里我们首先用 boxrule = 0.5mm 将文本框所有的框线设置为 0.5mm,而后按照上下左右标题的顺序,依次设置相应的框线为 3mm。
弧度
文本框的弧度也是可以定制的。并且,文本框的弧度,在 tcolorbox 中被细分为内弧和外弧,可以分别设置。默认情况下,外弧的弧度与内弧保持一致(auto outer arc)。
arc=⟨length⟩: 设置内弧的半径。outer arc=⟨length⟩: 设置外弧的半径,可以与内弧不同。auto outer arc: 让外弧的半径自动随着内弧的半径增减,默认启用。
tcb-arc.tex
1 |
\documentclass{article}
|

这里,第一个文本框,我们设置内弧的半径为 0mm,得到了一个直角;第二个文本框,我们设置内弧半径为 3mm,得到了一个比较圆润的边框;第三个文本框,我们设置内弧半径为 1mm,外弧半径为 4mm——与此同时,第四个文本框将内外弧半径调换,得到了两个有些另类的效果。
除了手工设置内外弧的半径之外,tcolorbox 还预定义了一些样式:circular arc、bean arc、octogon arc。
theorems 程序包
tcolorbox 宏包提供了 theorems 程序包来实现定理类的环境。theorems 程序包会自动加载 amsmath 宏包。加载调用的方法如前所述:
1 |
\tcbuselibrary{theorems}
|
基本用法
theorems 程序包提供了两个命令,来生成文本框样式的定理类环境。
\newtcbtheorem[⟨init options⟩]{⟨name⟩}{⟨display name⟩}{⟨options⟩}{⟨prefix⟩}\renewtcbtheorem[⟨init options⟩]{⟨name⟩}{⟨display name⟩}{⟨options⟩}{⟨prefix⟩}
两个命令分别都有 4 个必需参数和 1 个可选参数。
name: 创建的 LaTeX 环境名称display name: 创建的环境的标题名称options: 传入tcolorbox的参数prefix: 用于生成环境的labelinit options: 用于控制编号
我们来看几个例子。
tcb-theorem-basic.tex
1 |
\documentclass[UTF8]{ctexart}
|

选项
theorems 程序包也提供了诸多选项,用来控制生成的定理环境样式。
separator sign = ⟨sign⟩: 设置定理环境编号和标题之间的分隔符,默认是:。separator sign colon: 相当于separator sign = {:}separator sign dash: 相当于separator sign = {-}separator sign none: 相当于separator sign = {}
description delimiters={⟨left⟩}{⟨right⟩}: 设置定理标题左右的定界符,默认是空。description delimiters parenthesis: 相当于description delimiters = {(}{)}description delimiters none: 相当于description delimiters = {}{}
description color = ⟨color⟩: 设置定理标题的字体颜色。description font = ⟨text⟩: 设置定理标题的字体。terminator sign = ⟨sign⟩: 设置定理标题结束后的终止符。terminator sign colon: 相当于terminator sign = {:}terminator sign dash: 相当于terminator sign = {-}terminator sign none: 相当于terminator sign = {}
tcb-theorems-title.tex
1 |
\documentclass[UTF8]{ctexart}
|

实际动手制作一个定理环境看看
tcb-theorem-final.tex
1 |
\documentclass[UTF8]{ctexart}
|

这里我们调用了 skins/breakable/theorems 三个程序包,其中 theorems 我们已经见过了。skins 程序包提供了各种「皮肤」,可以在基础 tcolorbox 的基础上扩展更多样式:attach boxed title to top left 这一效果就来自 skins 程序包中的 enhanced 主题。breakable 的效果则使得文本框能够跨页。
其他的参数很好理解,就不用展开讲了。
希望你看过这篇文章之后,能够用 tcolorbox 宏包,制作出自己喜欢的文本框。
tcolorbox 宏包简明教程的更多相关文章
- Python 简明教程 --- 17,Python 模块与包
微信公众号:码农充电站pro 个人主页:https://codeshellme.github.io 正确的判断来源于经验,然而经验来源于错误的判断. -- Fred Brooks 目录 我们已经知道函 ...
- Lisp简明教程
此教程是我花了一点时间和功夫整理出来的,希望能够帮到喜欢Lisp(Common Lisp)的朋友们.本人排版很烂还望多多海涵! <Lisp简明教程>PDF格式下载 <Lisp简明教程 ...
- 2013 duilib入门简明教程 -- 第一个程序 Hello World(3)
小伙伴们有点迫不及待了么,来看一看Hello World吧: 新建一个空的win32项目,新建一个main.cpp文件,将以下代码复制进去: #include <windows.h> #i ...
- Docker简明教程
Docker简明教程 [编者的话]使用Docker来写代码更高效并能有效提升自己的技能.Docker能打包你的开发环境,消除包的依赖冲突,并通过集装箱式的应用来减少开发时间和学习时间. Docker作 ...
- [原创][LaTex]LaTex学习笔记之框架及宏包
0. 简介 LaTex在书写文档时的最基本单元就是首部的写作,变相的也可以说是头文件.本文章就来总结一下文档的基本格式和常用宏包. 1. 基本单元 基本单元需要对LaTex语法有一定的了解,这个很简单 ...
- Java8简明教程(转载)
ImportNew注:有兴趣第一时间学习Java 8的Java开发者,欢迎围观<征集参与Java 8原创系列文章作者>. 以下是<Java 8简明教程>的正文. “Java并没 ...
- appium简明教程
appium简明教程 什么是appium? 下面这段介绍来自于appium的官网. Appium is an open-source tool you can use to automate mobi ...
- Tips & Tricks:Apache log4j简明教程(一)
Apache log4j的官方介绍是“log4j is a reliable, fast and flexible logging framework (APIs) written in Java, ...
- ArcGIS Pro 简明教程(4)工具和模型构建器
ArcGIS Pro 简明教程(4)工具和模型构建器 by 李远祥 工具箱中的工具 ArcGIS Pro 在1.3版本基本上已经继承了ArcMap的所有工具,而且会不断加入一些它自身才有的工具,例如适 ...
随机推荐
- [dubbo 源码之 ]1. 服务提供方如何发布服务
服务发布 启动流程 1.ServiceConfig#export 服务提供方在启动部署时,dubbo会调用ServiceConfig#export来激活服务发布流程,如下所示: Java API: ` ...
- scanf函数中*修饰符的作用,如:%*d
在scanf函数中,*修饰符可以跳过所在项的输入.如下: #include <stdio.h> int main() { ; printf("请输入:"); scanf ...
- scrapy 当当网 爬虫
前言 好久没有写实战博客了,因为前几个月在公司实习,博客更新就耽搁了下来,现在又受疫情影响无法返校,但是技能还是不能丢的,今天就写一篇使用scrapy爬取当当网的实战练习吧. 创建scrapy项目 目 ...
- JAVA 增删改查接口命名规范(dao层与 service 层
开发时,有很多规范,这里写的是命名规范. Dao 接口命名 insert batchInsert selectOne selectById count selectList update dele ...
- Vue中import from的来源--省略后缀与加载文件夹
Vue使用import ... from ...来导入组件,库,变量等.而from后的来源可以是js,vue,json.这个是在webpack.base.conf.js中设置的: module.exp ...
- 关于非旋转Treap
刚刚跟着EM-LGH大佬学了非旋转Treap 非常庆幸不用再写万恶的rotate了(来自高级数据结构的恶意) 来记一下 Treap 概念 简单来说,\(Tree_{二叉搜索树} * Heap_堆 = ...
- FIB表与RIB表的区别与联系
RIB (route information base) 和 FIB (forwarding information base),又称Ip路由表 和 CEF表,它们之间的关系可以用下面这张图片来高度概 ...
- 自定义配置JNOJ
OJ 全名 online judge 在线判题系统,对于从事编程竞赛的人来说一点都不陌生,今天我们讨论的是怎么样自定义搭建 推荐的开源的OJ有hustOJ,JNOJ 因为hustOJ 是一键安装脚本, ...
- (办公)记事本_Linux查找命令
参考谷粒学院的linux视频教程:http://www.gulixueyuan.com/course/300/task/7091/show 搜索命令 .whereis命令: 1.1.Linux whe ...
- 第3章 关系数据库标准语言SQL(重点) | 数据库知识点整理
第3章 关系数据库标准语言SQL(重点) 了解 SQL语言发展过程 关系数据库技术和关系数据库管理系统RDBMS产品的发展过程 掌握 SQL语言的特点和优点 面向过程的语言和SQL语言的区别 关系数据 ...