互动小说及其开源简史
创始人
2024-03-02 03:24:22
0

了解开源如何促进互动小说的成长和发展。

互动小说技术基金会 Interactive Fiction Technology Foundation (IFTF) 是一个非营利组织,致力于保护和改进那些用来生成我们称之为 互动小说 interactive fiction 的数字艺术形式的技术。当 Opensource.com 的一位社区版主提出一篇关于 IFTF、它支持的技术与服务,以及它如何与开源相交织的文章时,我发现这对于我讲了数几十年的开源故事来说是个新颖的视角。互动小说的历史比 自由及开源软件 Free and Open Source Software (FOSS)运动的历史还要长,但同时也与之密切相关。希望你们能喜欢我在这里的分享。

定义和历史

对于我来说,互动小说这个术语涵盖了读者主要通过文本与之交互的任何视频游戏或数字化艺术作品。这个术语起源于 20 世纪 80 年代,当时由语法解析器驱动的文本冒险游戏确立了什么是家用电脑娱乐,在美国主要以 魔域银河系漫游指南Infocom 公司的其它佳作为代表。在 20 世纪 90 年代,它的主流商业价值被挖掘殆尽,但在线爱好者社区接过了该传统,继续发布这类游戏和游戏创建工具。

在四分之一个世纪之后的今天,互动小说包括了品种繁多并且妙趣橫生的作品,如从充满谜题的文字冒险游戏到衍生改良的超文本类型。定期举办的在线竞赛和节日为品鉴和试玩新作品提供了个好地方—英语互动小说世界每年都会举办一些活动,包括 Spring ThingIFComp。后者是自 1995 年以来现代互动小说的核心活动,这也使它成为在同类型活动中持续举办时间最长的游戏展示活动。IFComp 从 2017 年开始的评选和排名记录 显示了如今基于文本的游戏在形式、风格和主题方面的惊人多样性。

(作者注:以上我特指英语,因为可能出于写作方面的技术原因,互动小说社区倾向于按语言进行区分。例如也有 法语意大利语 的互动小说年度活动,我就听说过至少一届的中文互动小说节。幸运的是,这些边界易于打破。在我管理 IFComp 的四年中,我们很欢迎来自国际社区的所有英语翻译工作。)

“假冒的猴子”游戏截图

在解释器 Lectrote 上启动 Emily Short 的“假冒的猴子”新游戏(二者皆为开源软件)。

此外由于互动小说专注于文本,它为玩家和作者都提供了最方便的平台。几乎所有能阅读数字化文本的人(包括能通过文字转语音软件等辅助技术阅读的用户)都能玩大部分的互动小说作品。同样,互动小说的创作对所有愿意学习和使用其工具和技术的作家开放。

这使我们了解了互动小说与开源的长期关系,以及从它的全盛时期以来,对于艺术形式可用性的积极影响。接下来我将概述当代开源互动小说创建工具,并讨论共享源代码的互动小说作品古老且有点稀奇的传统。

开源互动小说工具的世界

一些开发平台(其中大部分是开源的)可用于创建传统的语法解析器驱动互动小说,其中用户可通过输入命令(如 向北走拾取提灯收养小猫向 Zoe 询问量子机械学)来与游戏世界交互。20 世纪 90 年代初期出现了几个 适于魔改 hacker-friendly 的语法解析器游戏开发工具,其中目前还在使用的有 TADSAlanQuest,它们都是开源的,并且后两者兼容 FOSS 许可证。

其中最出名的是 Inform,1993 年 Graham Nelson 发布了第一个版本,目前由 Nelson 领导的一个团队进行维护。Inform 的源代码是不太寻常的半开源:Inform 6 是前一个主要版本,它通过 Artistic 许可证开放源码。这其中蕴涵着比我们所看到的更直接的相关性,因为它专有的 Inform 7 将 Inform 6 作为其核心,可以让它在将作品编译为机器码之前,将其 杰出的自然语言语法 (LCTT 译注:此链接已遗失)翻译为其前一代的那种更类似 C 的代码。

inform 7 集成式开发环境截图

Inform 7 集成式开发环境,打开了文档以及一个示例项目

Inform 游戏运行在虚拟机上,这是 Infocom 时代的遗留产物。当时的发行者为了让同一个游戏可以运行在 Apple II、Commodore 4、Atari 800 以及其它种类的“家用计算机”上,将虚拟机作为解决方案。这些原本流行的操作系统中只有少数至今仍存在,但 Inform 的虚拟机使得它创建的作品能够通过 Inform 解释器运行在任何的计算机上。这些虚拟机包括相对现代的 Glulx,或者通过对 Infocom 过去的虚拟机进行逆向工程克隆得到的可爱的古董 Z-machine。现在,流行的跨平台解释器包括如 lectroteGargoyle 等桌面程序,以及如 QuixeParchment 等基于浏览器的程序。以上所有均为开源软件。

如其它的流行开源项目一样,如果 Inform 的发展进程随着它的成熟而逐渐变缓,它为我们留下的最重要的财富就是其活跃透明的生态环境。对于 Inform 来说,(这些财富)包括前面提到的解释器、一套语言扩展(通常混合使用 Inform 6 和 Inform 7 写成),当然也包括所有用它们写成并分享于全世界的作品,有的时候也包括那些源代码。(在这篇文章的后半部分我会回到这个话题)

互动小说创建工具发明于 21 世纪,力求在传统的语法解析器之外探索一种新的玩家交互方式,即创建任何现代 Web 浏览器都能加载的超文本驱动作品。其中的领头羊是 Twine,原本由 Klimas 在 2009 年开发,目前是 GNU 许可证开源项目,有许多贡献者正在积极开发。(事实上,Twine 的开源软件血统可追溯到 TiddlyWiki,Klimas 的项目最初是从该项目衍生而来的)

对于互动小说开发来说,Twine 代表着一系列最开放及最可用的方法。由于它天生的 FOSS 属性,它将其输出渲染为一个自包含的网站,不依赖于需要进一步特殊解析的机器码,而是使用开放并且成熟的 HTML、CSS 和 JavaScript 标准。作为一个创建工具,Twine 能够根据创建者的技能等级,展示出与之相匹配的复杂度。拥有很少或没有编程知识的用户能够创建简单但是可玩的互动小说作品,但那些拥有更多编码和设计技能(包括通过开发 Twine 游戏获得的技能提升)的用户能够创建更复杂的项目。这也难怪近几年 Twine 在教育领域的曝光率和流行度有不小的提升。

另一些值得注意的开源互动小说开发项目包括由 Ian Millington 开发的以 MIT 许可证发布的 Undum,以及由 Dan Fabulich 和 Choice of Games 团队开发的 ChoiceScript,两者也专注于将 Web 浏览器作为游戏平台。除了以上专用的开发系统以外,基于 Web 的互动小说也呈现给我们以开源作品的丰富、变幻的生态。比如 Furkle 的 Twine 扩展工具集,以及 Liza Daly 为自己的互动小说游戏创建的名为 Windrift 的 JavaScript 框架。

程序、游戏,以及游戏程序

Twine 受益于 一个致力于提供支持的长期 IFTF 计划,公众可以为其维护和发展提供资助。IFTF 还直接支持两个长期公共服务:IFComp 和 互动小说归档 IF Archive ,这两个服务都依赖并回馈开源软件和技术。

Harmonia 开场截图

由 Liza Daly 开发的“Harmonia”的开场画面,该游戏使用 Windrift 开源互动小说创建框架创建。

自 2014 年以来,用于运行 IFComp 网站的基于 Perl 和 JavaScript 的应用程序一直是 一个共享源代码项目,它反映了 互动小说特有子组件使用的 FOSS 许可证是个大杂烩,其中包括那些可以让以语法解析器驱动的竞争项目在 Web 浏览器中运行的各式各样的代码库。在 1992 年上线并 在 2017 年成为一个 IFTF 项目 的 互动小说归档 IF Archive ,是一套完全基于古老且稳定的互联网标准的镜像仓库,只使用了 一点开源 Pyhon 脚本 用来处理索引。

最后,也是最有趣的部分,让我们聊聊开源文字游戏

互动小说归档的主体 由游戏组成,当然,是那些历经岁月的游戏。它们反映了数十年来不断发展的游戏设计趋势和互动小说工具发展。

许多互动小说作品都共享其源代码,要快速找到它们的快速很简单 —— 在 IFDB 中搜索标签 “source available”。IFDB 是另一个长期运行的互动小说社区服务,由 TADS 的创立者 Mike Roberts 私人运营。对更加简单的界面感到舒适的用户,也可以浏览互动小说归档的 games/source 目录,该目录按开发平台和编写语言对内容运行分组(也有很多作品,由于太繁杂或太古老而无法分类,只能浮于顶级目录)。

对这些代码共享游戏随机抽取的几个样本,揭示了一个有趣的窘境:与更广阔的开源软件世界不同,互动小说社区缺少一种普遍认同的方式来授权它生成的所有代码。与软件工具(包括我们用来创建互动小说的所有工具)不同的是,从字面意思上讲,交互式小说游戏是一件艺术作品。这意味着,将面向软件的开源许可证用于交互式小说游戏,并不会比将其用于其它像散文或诗歌作品更适合。但同样,互动小说游戏也是一个软件,它展示了创建者希望合法地与世界分享的源代码模式和技术。一个拥有开源意识的互动小说创建者会怎么做呢?

有些游戏通过将其代码放到公共领域来解决这一问题,或者通过明确的许可证,亦或者如 42 年前由 Crowther 和 Woods 开发的“ 冒险之旅 Adventure ” 一样通过社区发布。一些人试图将其中的不同部分分开,应用他们自己的许可证,允许免费复用游戏公开的业务逻辑,但禁止针对其散文内容的再创作。这是我在开源自己的游戏 莺巢 The Warbler’s Nest 时采取的策略。天知道这是否能在法律上站得住脚,但我当时没有更好的主意。

当然,你会发现一些作品对所有部分使用单一的许可证,而不介意反对者。一个突出的例子就是 Emily Short 的史诗作品“ 假冒的猴子 Counterfeit Monkey ”,其全部采用 Creative Commons 4.0 许可证发布。CC 对其应用于代码感到不满,但你可以认为 Inform 7 源码这种不寻常的散文风格特性 至少比传统的软件项目更适合 CC 许可证。

接下来要做什么呢,冒险者?

如果你希望开始探索互动小说的世界,这里有几个链接可供你参考:

  • 如上所述,IFDB互动小说归档都提供了可浏览的界面,用于浏览超过 40 年价值的互动小说作品。其中大部分可以在 Web 浏览器中玩,但有些需要额外的解释器程序。IFDB 能帮助你找到并安装它们。IFComp 的年度结果页面展现了另一个视图,帮助你了解最佳的免费和归档可用作品。
  • 互动小说技术基金会是一个非营利组织,主要帮助并支持 Twine、IFComp 和互动小说归档的发展,以及提升互动小说的无障碍功能、探索互动小说在教育领域中的应用等等。加入其邮件列表,可以接收 IFTF 的每月资讯,浏览其博客,亦或浏览一些主题商品
  • 在今年的早些时候,John Paul Wohlscheid 写了这篇关于开源互动小说工具的文章。它涵盖了一些这里没有提及的平台,所以如果你还想了解更多,请看一看这篇文章。

via: https://opensource.com/article/18/7/interactive-fiction-tools

作者:Jason Mclntosh 选题:lujun9972 译者:cycoe 校对:wxy

本文由 LCTT 原创编译,Linux中国 荣誉推出

相关内容

沙尘暴突袭甘肃敦煌,游客:...
7月29日下午,甘肃敦煌突遇沙尘暴,漫天的黄沙将城市笼盖。受此影响...
2025-07-30 22:43:44
宝树:梁羽生的苦恼与AI创...
在我们之上有无限遥远的高处,在我们之下也有低到深渊的低处,一切残酷...
2025-07-24 15:14:23
《水星逆行》对谈:科幻折叠...
科幻想象,一定要想象未来吗?今年出版的科幻小说集《水星逆行》回应了...
2025-06-07 11:12:38
Python采集--小说一...
前言 嗨喽~大家好呀,这里是魔王呐 ❤ ~! 不知...
2025-05-30 06:31:45
AI成小说“枪手”,投稿抢...
图/IC “他走进铁锈般的大门,看见地上凌乱的……”网文编辑周岐扫...
2025-05-27 10:48:55
男子用AI写色情小说售卖7...
据人民法院新闻传媒总社消息,2022年11月至2023年3月期间,...
2025-03-22 23:18:24

热门资讯

Helix:高级 Linux ... 说到 基于终端的文本编辑器,通常 Vim、Emacs 和 Nano 受到了关注。这并不意味着没有其他...
《Apex 英雄》正式可在 S... 《Apex 英雄》现已通过 Steam Deck 验证,这使其成为支持 Linux 的顶级多人游戏之...
使用 KRAWL 扫描 Kub... 用 KRAWL 脚本来识别 Kubernetes Pod 和容器中的错误。当你使用 Kubernet...
JStock:Linux 上不... 如果你在股票市场做投资,那么你可能非常清楚投资组合管理计划有多重要。管理投资组合的目标是依据你能承受...
Epic 游戏商店现在可在 S... 现在可以在 Steam Deck 上运行 Epic 游戏商店了,几乎无懈可击! 但是,它是非官方的。...
从 Yum 更新中排除特定/某... 作为系统更新的一部分,你也许需要在基于 Red Hat 系统中由于应用依赖排除一些软件包。如果是,如...
通过 SaltStack 管理... 我在搜索Puppet的替代品时,偶然间碰到了Salt。我喜欢puppet,但是我又爱上Salt了:)...
如何在 Github 上创建一... 学习如何复刻一个仓库,进行更改,并要求维护人员审查并合并它。你知道如何使用 git 了,你有一个 G...
Opera 浏览器内置的 VP... 昨天我们报道过 Opera 浏览器内置了 VPN 服务,用户打开它可以防止他们的在线活动被窥视。不过...
如何检查你的 Linux 系统... 不知道在使用哪个初始化系统?以下是方法。每个主流 Linux 发行版(包括 Ubuntu、Fedor...