Project Icon

texpresso

为LaTeX编辑提供实时渲染和即时错误反馈

TeXpresso是一个开源的LaTeX编辑辅助工具,其核心特点是实时渲染和即时错误反馈。它可以与Emacs、Neovim和Visual Studio Code等编辑器集成,让编辑者能够即时看到文档变化。TeXpresso的查看器支持页面导航、缩放和主题切换等功能,进一步优化了LaTeX编辑体验。该项目目前处于活跃开发阶段,不断进行功能改进和问题修复。

TeXpresso:LaTeX的实时渲染和错误报告

注意:TeXpresso仍处于早期开发阶段。变更和错误修复频繁发生,请查看CHANGELOG.md

重要:此仓库使用子模块。请使用 git clone --recurse-submodules 克隆。

关于

TeXpresso在支持的编辑器中编辑LaTeX文档时提供"实时渲染"体验:在.tex文件中进行更改,渲染窗口几乎立即更新您的更改。如果输入无效内容,您会立即收到错误消息。

与常规的重新构建并等待查看器更新的体验相比,这可以显著改善LaTeX编辑体验,尤其是对于大型文档。

请查看本文件末尾的屏幕录像,直观了解TeXpresso的功能。

安装

TeXpresso已在Linux和macOS上测试,应该适用于AMD64和Apple Silicon架构。有关依赖项和构建说明,请参阅INSTALL.md

设计

TeXpresso系统由以下部分组成:

  1. 将LaTeX文档渲染为PDF的TeX引擎; 我们使用经过修改的Tectonic引擎,修改后可与TeXpresso驱动程序交互。

    这位于tectonic/ git子模块中,它生成texpresso-tonic辅助二进制文件

  2. 将PDF文档渲染为图像的PDF渲染器。 我们使用MuPDF

  3. 使用libSDL构建的查看器,用于显示渲染图像并允许简单的用户命令(请参阅下面的查看器控制)。

  4. 驱动程序与编辑器通信以获取LaTeX文档的更改通知,维护文档和渲染过程的增量视图(支持增量性、回滚、错误恢复等),与LaTeX引擎通信以重新渲染文档的修改部分,并与查看器同步。

    驱动程序是"实时"魔法所在。它是texpresso二进制文件,其源代码位于此仓库中。

驱动程序在编辑器和渲染器之间双向发送信息。特别是,可以通过点击查看器窗口要求编辑器跳转到LaTeX文档中的特定位置,反之亦然,可以刷新查看器窗口以显示编辑器位置的文档。

查看器控制

键盘控制:

  • :翻页
  • :在页面内移动
  • p("page"):在"适合页面"和"适合宽度"缩放模式之间切换
  • c("crop"):裁剪边框
  • q("quit"):退出
  • i("invert"):暗模式
  • I:切换主题
  • t("top"):切换置顶(保持TeXpresso在编辑器窗口之上)
  • b("border"):切换窗口边框
  • F5:开始全屏演示(按ESC退出)

鼠标控制:

  • 点击:在窗口中选择文本(待实现:使用SyncTeX移动Emacs缓冲区)
  • Control+点击:平移页面
  • 滚轮:滚动页面
  • Control+滚轮:缩放

支持的编辑器

Emacs

TeXpresso附带Emacs模式。源代码可在emacs/texpresso.el中找到。在Emacs中加载此文件(使用M-X load-file;它也兼容require)。

使用M-x texpresso启动TeXpresso。提示将让您选择主/根TeX文件。 它将尝试启动texpresso命令。如果无法启动,它将打开 (customize-variable 'texpresso-binary)让您设置texpresso 二进制文件的路径(<您克隆仓库的位置>/build/texpresso)。

为了正确工作,texpresso需要texpresso-tonic辅助程序;复制时,请确保它们都在同一目录中。

M-x texpresso-display-output将打开一个小窗口,列出当前页面的TeX警告和错误。 使用M-x texpresso-next-pageM-x texpresso-previous-page在不离开Emacs的情况下在页面之间移动。

Neovim

Neovim模式在单独的仓库texpresso.vim中提供。它尚不兼容原版Vim,欢迎贡献补丁 :bow:。

Visual Studio Code

vscode模式正在texpresso-vscode中开发,感谢@DominikPeters。 在市场中查找TeXpresso

屏幕录像

Neovim集成。 在vim中启动TeXpresso:

https://github.com/let-def/texpresso.vim/assets/1048096/b6a1966a-52ca-4e2e-bf33-e83b6af851d8

编辑时实时更新:

https://github.com/let-def/texpresso.vim/assets/1048096/cfdff380-992f-4732-a1fa-f05584930610

使用Quickfix窗口交互式修复错误和警告:

https://github.com/let-def/texpresso.vim/assets/1048096/e07221a9-85b1-44f3-a904-b4f7d6bcdb9b

从文档到编辑器的同步(SyncTeX向后):

https://github.com/let-def/texpresso.vim/assets/1048096/f69b1508-a069-4003-9578-662d9e790ff9

从编辑器到文档的同步(SyncTeX向前):

https://github.com/let-def/texpresso.vim/assets/1048096/78560d20-391e-490e-ad76-c8cce1004ce5

主题,明/暗模式:😎

https://github.com/let-def/texpresso.vim/assets/1048096/a072181b-82d3-42df-9683-7285ed1b32fc

Emacs集成。 这是我在TeXpresso中编辑和浏览@fabiensanglard的Game Engine Black Book: Doom的示例录像(使用我的emacs主题):

https://user-images.githubusercontent.com/1048096/235424858-a5a2900b-fb48-40b7-a167-d0b71af39034.mp4

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号