Zh/Gameinfo.txt: Difference between revisions
| No edit summary | No edit summary | ||
| Line 68: | Line 68: | ||
| <code>SteamAppId</code> 的值制定了游戏要使用的内容 (就是 [[GCF]] 文件). | <code>SteamAppId</code> 的值制定了游戏要使用的内容 (就是 [[GCF]] 文件). | ||
| {{note| | {{note|所有的 MOD 应该都使用 <code>215</code> AppId, 除非有特殊的需要, 比如 218 是读取 the Orange Box Source 引擎.}} | ||
| {{warning| | {{warning|选择您的 MOD 所以依赖的游戏时, 注意 '''您将不能依赖于那些其他游戏没有共享的内容.'''}} | ||
| {{warning|''' | {{warning|'''要让 VAC 反作弊系统保护您的多人游戏 MOD, 请确定 MOD 是基于一个多人游戏'''. [[HL2DM]] 是个不错的选择.}} | ||
| Source 引擎游戏的 <code>SteamAppId</code> 的值可以在 [[Steam Application IDs]] 找到. 共享 GCFs 将在文件名中包含 'shared' , 这些文件可以随时被调用; 剩下的一切就是个人的问题了. | |||
| ==  | == 文件系统 == | ||
| 这一段详细描述了文件系统中的大量组件 | |||
| === ToolsAppId === | === ToolsAppId === | ||
| 所有 <code>GameInfo.txt</code> 文件都有这样的一行: | |||
|   ToolsAppId 211	//Tools will load this (ie: source SDK caches) to get |   ToolsAppId 211	//Tools will load this (ie: source SDK caches) to get | ||
Revision as of 19:57, 21 July 2008
GameInfo.txt 文件用来向 SDK 工具 和 Source 引擎 传递 MOD 或游戏中要使用到的文件. 这就是在运行 MOD 的时候 SDK 和 Source 引擎查看要调用的是 Half-Life 2, Counter-Strike, 还是 Half-Life 2: Deathmatch 中的内容. 这也是 SDK 工具来找到您的 MOD 所在文件夹的一种途径.
 注意:对于 Half-Life 1 (GoldSrc), 请看 liblist.gam 的文件结构.
注意:对于 Half-Life 1 (GoldSrc), 请看 liblist.gam 的文件结构.仅仅当一个程序员刚刚建立起一个 MOD 时, 才需要修改这个文件了. 在大多时间里, 您不需要修改此文件, 但是如果您希望您的 MOD 能够调用除了 Half-Life 2 之外的其他内容, 您就需要修改它了. 只要您 MOD 中的这个文件设置好了, 它就应该和您的 MOD 内容放置在一起. 当所有开发者工作时, 必须使用同一个 gameinfo.txt.
UI 设定
许多的 UI 设定, 包括您的游戏标题, 都是由 gameinfo.txt 文件来控制的. 包含的关键字:
 注意:布尔 (Boolean) 值是以整型 (int) 来表示.
注意:布尔 (Boolean) 值是以整型 (int) 来表示.//基本信息 game "Game Title" // 这里的文字就是 Steam 游戏菜单中显示的内容. gamelogo boolean // 当打开这个选项的时候 // 显示的就不是 title/title2 的文本了 //而是显示resource/GameLogo.res文件里面的内容. // 设定将被读取到引擎的 VGUI // 以便使用gamelogo文件来修改. title "Game Title" // 这是在游戏中的菜单上显示的实际内容. title2 "..." // 副标题 (非必需) type singleplayer_only // 也可以是 multiplayer_only . 帮助 GameUI 了解 // 在 选项 面板上哪些 UI 组件是要显示的. // 如果 MOD 结合了 多人模式 和 单人模式 就可以忽略此项了. // 如果设置了multiplayer_only, 那么 多人游戏 标签 // 将显示在 选项 面板的最前面 // 否则, 如果没有singleplayer_only它会被添加到最后.
nodifficulty boolean // 在 选项 面板上隐藏 困难度标签 hasportals boolean // 在 选项 面板上显示 Portal 标签 //选项 面板上的 多人游戏 标签 nocrosshair boolean // 隐藏 准心选择 面板 nohimodel boolean // Hides cvar toggles checkbox forcl_himodels// Only is displayed properly ifcl_himodelsis registered nomodels boolean // 隐藏多人游戏中的 模型选择 标签 //Steam 游戏列表 developer "Team name" // 您的团队的名字 (或许只有您一人!) developer_url "Web address" // 您团队的主页. 必须把 http:// 卸载最前面. manual "URL" // 游戏手册的地址; 也可以是本地目录. // 安装文件可以修改这个值 // 以便在安装时修正文件位置. icon "path/to/icon" // 图标必须为未压缩的 16x16 像素的 TGA 格式文件. // 为了使透明度正常, TGA 文件必须以拥有 Alpha 通道的 32-bit 模式储存 // 路径为 相对 MOD 安装目录的 相对路径 // (就是gameinfo.txt文件) // 还应该不含有 .TGA 扩展名. //创建服务器会话 hidden_maps // 括号内的地图将不会显示 { // 但是通过 自动完成 列表 "mapname" 1 // 和changelevel命令 "mapname" 1 // 可以打开. } nodegraph boolean // 告诉引擎是否要生成地图的 nodegraphs.
当您创建一个新 MOD 的时候, gameinfo.txt 文件内的 标题 (title) 和 游戏类型 (type) 都是空的, 别忘了自己写上.
 注意:在您更改
注意:在您更改 resource/clientscheme.res文件中 标题 所用的字体之前, 标题可能无法正常显示. Half-Life 2 使用一个独特定制的字体 ("HalfLife2") 里面只包含有一堆的特殊图形; 这个字体无法正常显示大多数的文本.  改变 clientscheme.res 文件内的 ClientTitleFontto 项的字体列表 来修正这个问题.SteamAppId
GameInfo.txt 文件内有用的还有 SteamAppId 的值. 如果您打开 GameInfo.txt, 您将看到这样的一块:
SteamAppId 215 //This will mount all the GCFs we need (240=CS:S, 220=HL2).
SteamAppId 的值制定了游戏要使用的内容 (就是 GCF 文件).
 注意:所有的 MOD 应该都使用
注意:所有的 MOD 应该都使用 215 AppId, 除非有特殊的需要, 比如 218 是读取 the Orange Box Source 引擎. 警告:选择您的 MOD 所以依赖的游戏时, 注意 您将不能依赖于那些其他游戏没有共享的内容.
警告:选择您的 MOD 所以依赖的游戏时, 注意 您将不能依赖于那些其他游戏没有共享的内容. 警告:要让 VAC 反作弊系统保护您的多人游戏 MOD, 请确定 MOD 是基于一个多人游戏. HL2DM 是个不错的选择.
警告:要让 VAC 反作弊系统保护您的多人游戏 MOD, 请确定 MOD 是基于一个多人游戏. HL2DM 是个不错的选择.Source 引擎游戏的 SteamAppId 的值可以在 Steam Application IDs 找到. 共享 GCFs 将在文件名中包含 'shared' , 这些文件可以随时被调用; 剩下的一切就是个人的问题了.
文件系统
这一段详细描述了文件系统中的大量组件
ToolsAppId
所有 GameInfo.txt 文件都有这样的一行:
ToolsAppId 211 //Tools will load this (ie: source SDK caches) to get //things like materials\debug, materials\editor, etc.
This is a special case that tools use so they can load special content that is used by the tools, but is not used by the games.
SearchPaths
The SearchPaths section of the GameInfo.txt file describes where the content is to be found, either on your hard drive or inside Steam cache files. To understand this part, we must take a detour into how programmers using the Source engine access the game's files. All files that a programmer accesses in code must exist under a path ID. A path ID describes one or more locations on your hard drive or inside virtual Steam file systems.
As an example, most of your game's resources like scripts, sounds, model files, and materials are accessed under the "Game" path ID. A programmer might say, "open a file called scripts\weapon_m4a1.txt inside the 'Game' path ID". If you were running a mod in C:\MyMod\Blasters, and you used SteamAppId 240 which would load in the Counter-Strike: Source content, then it would look for the file in these locations:
- C:\MyMod\Blasters\scripts\weapon_m4a1.txt
- <Steam install directory>\Steam\SteamApps\username\Counter-Strike Source\cstrike\scripts\weapon_m4a1.txt
- <inside the virtual Steam file system>\cstrike\scripts\weapon_m4a1.txt
Using path IDs to describe where the files are saves the programmer and artist from having to worry about all these different directories. They can use names relative to the game directory (like scripts\weapon_m4a1.txt or materials\brick\brickwall001a.vmt) and the engine and tools will find the full path to the file wherever it exists, as long as GameInfo.txt describes what the "Game" path ID means.
Inside the GameInfo.txt file, there is a section called "SearchPaths", which describes the path IDs. Most mods will never need to modify the way these are setup from the way they are created when you run Create a Mod from the SDK launcher.
The first part of each line is the name of the path ID, and the second part is where to look for files when this path ID is used. A simple example, which is illustrative, but you would never use (because it uses absolute paths including drive letters, which you can never assume exist on a user's machine) is this:
SearchPaths
{
	TestPathID	C:\TestMod1
	TestPathID	C:\TestMod2
	TestPathID	C:\TestMod3
}
If a programmer were to write code that asked for scripts\weapon_m4a1.txt and specify "TestPathID" as the path ID in code, then the engine would look for the file in these locations:
- C:\TestMod1\scripts\weapon_m4a1.txt
- C:\TestMod2\scripts\weapon_m4a1.txt
- C:\TestMod3\scripts\weapon_m4a1.txt
Since the Source games access most of their content in the "Game" path ID, they do some things for you automatically if you have a path ID called "Game". For each entry with a path ID of "Game":
- It adds a "GameBin"path ID, in<dir>\bin
- It adds another "Game"path in front of it with_<language>at the end. For example:c:\hl2\cstrikewould get ac:\hl2\cstrike_frenchpath added to it if you were running on a French-localized machine.
For the first "Game" search path:
- It adds a search path called "MOD"under the same folder.
- It adds a search path called "DEFAULT_WRITE_PATH".
The default SearchPaths that would be used in most mods are like this:
SearchPaths
{
	Game        |gameinfo_path|.
	Game        hl2
}
Normally, a path specifier (the part on the right side) is relative to the base directory --The directory where hl2.exe is found. If |gameinfo_path| precedes the path, then it is relative to the directory where GameInfo.txt file instead. For example, if the GameInfo.txt file were in C:\MyMod\Blasters, and it had a path like |gameinfo_path|SomeTestDirectory, then the path ID you were creating would refer to:
C:\MyMod\Blasters\SomeTestDirectory
For Counter-Strike: Source, the GameInfo.txt file has a SearchPaths section that looks like the one above. If your Counter-Strike directory was:
C:\Program Files\Valve\Steam\SteamApps\username\Counter-Strike Source
then it would be saying to look in these two directories:
- C:\Program Files\Valve\Steam\SteamApps\username\Counter-Strike Source\cstrike
because GameInfo.txt exists here.
- C:\Program Files\Valve\Steam\SteamApps\username\Counter-Strike Source\hl2
which only exists inside a virtual Steam file system.
Template:Otherlang:zh-cn Template:Otherlang:zh-cn:en Template:Otherlang:zh-cn:ru Template:Otherlang:zh-cn:pl Template:Otherlang:zh-cn:jp