十字军之王3
ParaWikis
最新百科
都市天际线2百科
英雄无敌3百科
维多利亚3百科
奇妙探险队2百科
罪恶帝国百科
英白拉多:罗马百科
热门百科
群星百科
欧陆风云4百科
十字军之王2百科
十字军之王3百科
钢铁雄心4百科
维多利亚2百科
ParaWikis
申请建站
ParaWikis
ParaCommons
最近更改
随机页面
加入QQ群
工具
链入页面
相关更改
特殊页面
页面信息
页面值
帮助
译名手册
字词转换
编辑指南
编辑规范
练手沙盒
资助我们
×
欢迎访问十字军之王3百科!
注册一个账号
,一起参与编写吧!这里是
当前的工程
。
全站已采用新UI,任何使用上的问题请点击
这里
。欢迎所有对百科感兴趣的同学加入QQ群:
497888338
。
阅读
编辑
编辑源代码
查看历史
讨论
编辑“
界面
”
221.1.103.4
(
讨论
)
2020年11月17日 (二) 14:03的版本
(
→GUI Editor
)
(
差异
)
←上一版本
|
最后版本
(
差异
) |
下一版本→
(
差异
)
警告:您正在编辑的是本页面的旧版本。
如果您发布该更改,该版本后的所有更改都会丢失。
警告:
您没有登录。如果您做出任意编辑,您的IP地址将会公开可见。如果您
登录
或
创建
一个账户,您的编辑将归属于您的用户名,且将享受其他好处。
反垃圾检查。
不要
加入这个!
切换编辑器
您已切换至源代码编辑
关闭
您可以随时通过点击该图标切换回可视化编辑。
可视化编辑
源代码编辑
更多
高级
特殊字符
帮助
标题
2级
3级
4级
5级
格式
插入
拉丁字母
扩展拉丁字母
国际音标
符号
希腊字母
希腊字母扩展
西里尔字母
阿拉伯字母
扩展阿拉伯字母
希伯来字母
孟加拉语字符集
泰米尔数字和符号
泰卢固语字符集
僧伽罗语字符集
梵文字符集
古吉拉特语字符集
泰语字符集
老挝语
高棉语字母
加拿大原住民音节文字
卢恩
Á
á
À
à
Â
â
Ä
ä
Ã
ã
Ǎ
ǎ
Ā
ā
Ă
ă
Ą
ą
Å
å
Ć
ć
Ĉ
ĉ
Ç
ç
Č
č
Ċ
ċ
Đ
đ
Ď
ď
É
é
È
è
Ê
ê
Ë
ë
Ě
ě
Ē
ē
Ĕ
ĕ
Ė
ė
Ę
ę
Ĝ
ĝ
Ģ
ģ
Ğ
ğ
Ġ
ġ
Ĥ
ĥ
Ħ
ħ
Í
í
Ì
ì
Î
î
Ï
ï
Ĩ
ĩ
Ǐ
ǐ
Ī
ī
Ĭ
ĭ
İ
ı
Į
į
Ĵ
ĵ
Ķ
ķ
Ĺ
ĺ
Ļ
ļ
Ľ
ľ
Ł
ł
Ń
ń
Ñ
ñ
Ņ
ņ
Ň
ň
Ó
ó
Ò
ò
Ô
ô
Ö
ö
Õ
õ
Ǒ
ǒ
Ō
ō
Ŏ
ŏ
Ǫ
ǫ
Ő
ő
Ŕ
ŕ
Ŗ
ŗ
Ř
ř
Ś
ś
Ŝ
ŝ
Ş
ş
Š
š
Ș
ș
Ț
ț
Ť
ť
Ú
ú
Ù
ù
Û
û
Ü
ü
Ũ
ũ
Ů
ů
Ǔ
ǔ
Ū
ū
ǖ
ǘ
ǚ
ǜ
Ŭ
ŭ
Ų
ų
Ű
ű
Ŵ
ŵ
Ý
ý
Ŷ
ŷ
Ÿ
ÿ
Ȳ
ȳ
Ź
ź
Ž
ž
Ż
ż
Æ
æ
Ǣ
ǣ
Ø
ø
Œ
œ
ß
Ð
ð
Þ
þ
Ə
ə
格式
链接
标题
列表
文件
参考
讨论
说明
输入内容
输出结果
斜体
''斜体文字''
斜体文字
粗体
'''粗体文字'''
粗体文字
粗斜体
'''''粗斜体文字'''''
粗斜体文字
{{Version|timeless}}{{需要翻译}} CK3的用户界面(UI)是高度可修改的,但由于这个原因,UI修改器会禁用成就,因为玩家可能会用它们作弊。 游戏还包含一个GUI编辑器,可以在游戏中检查UI元素并编辑它们。 mod作者可以: *改变界面的视觉风格 * 使窗口可以移动和调整大小。 * 更改和删除要素 * 增加新的按钮 * 从代码中显示更多信息 * 增加新的窗口(有一个变通办法) mod作者不能: * 增加新的热键(只能重复使用现有的热键)。 * 在另一个窗口中显示一个窗口的信息,除非开发者包含这种可能性。 == Basics == The interface in CK3 is created through .gui files in the game/gui folder, which are somewhat similar to html files. As such, you can edit them with any text editor, like [[Modding#Tips_.26_guidelines | VS Code, Sublime or Atom]]. Choose Python or Perl 6 for syntax highlighting, they fit well. CK3 uses .dds files for textures, which are saved inside the game/gfx/ folder. To edit or save .dds files use either Photoshop with [https://software.intel.com/en-us/articles/intel-texture-works-plugin Intel plugin] or GIMP with [https://code.google.com/archive/p/gimp-dds/downloads this plugin]. To reload gui files in the game and use the GUI editor, add -debug_mode and -develop launch options: * right-click the game on Steam, choose Properties, Set Launch Options, add <code>-debug_mode -develop</code> You can use the following console commands: * <code>reload gui</code> - reloads all gui files to display any changes in the game * <code>reload texture</code> - reloads all texture files * <code>gui editor</code> - opens the GUI editor * <code>tweak gui.debug</code> - allows to enable highlighting of UI elements. The tooltips will display their name, size and position. * <code>DumpDataTypes</code> - will create a data_types.log in your log folder (Documents/Paradox Interactive/Crusader Kings III/logs) listing all available GUI functions for each window/game object Other tips: * always have the error log open to see if there is a mistake in the code (it's in the same log folder) * enable the error tracker in the game by clicking "Toggle Release Mode" below the console, to see if your changes craeted any new errors * mute the game when using <code>reload gui</code> command, as it triggers the intro sound every time * use [https://steamcommunity.com/sharedfiles/filedetails/?id=2269399705 Reload GUI mod] that adds a button to reload gui (with a hotkey) and closes the Settings window when you reload * add the gui folder to your text editor, so it uses it for autocompletion * you can use test_gui.gui in gui/debug for testing. To show this window, open the console and click Test Window. * fold code so it's easier to see its structure. Usual hotkeys are Ctrl+K, Ctrl+1 (where 1 is the level at which to fold the code). == 创建GUImod == 1. 启动游戏启动器,进入Mods,Mod Tools,填写所有字段,包括标签。 点击创建会在<code>Documents/Paradox Interactive/Crusader Kings III/mod</code>中新建一个文件夹和一个.mod文件。 2. 接下来,在你的mod里创建一个 "gui "文件夹,然后从game/gui里复制你要修改的文件到那里。 * 如果你不知道需要哪个文件,请使用GUI编辑器,在游戏中检查它。 == GUI Editor == GUI Editor是一款用于编辑游戏中UI的开发者工具。 要使用它,你需要在<code>-debug_mode</code>和<code>-developer</code>选项下启动游戏。 要打开编辑器,可以选择 * 按Ctrl+F8键 * 用`键(在Esc下面)打开控制台,点击GUI编辑器。 * 打开控制台,运行gui_editor命令。 === 特点 === 默认情况下,编辑器启动时启用了编辑模式。你可以在顶部窗口中禁用它,称为Outliner。热键 "E"。 * 编辑模式类似于浏览器中的检查模式。当它被启用时,你不能与游戏互动,但它允许你选择UI的部分,并在下面的属性窗口中更改它们。 * 用鼠标滚轮滚动来改变编辑器应该关注的元素,因为hud.gui往往会被放在其他窗口的顶部。 * 黄色边框表示选中的元素。要隐藏其他边框,请取消勾选Outliner中的 "Show Hierarchy"(热键 "L")。 * 按住鼠标右键可以移动所选元素。 * 要撤销任何操作,请按Ctrl+Z或大纲中的撤销按钮。重做是旁边的Ctrl+Y。 * Outliner中的红星*表示未保存的更改。按Ctrl+S或顶部的保存按钮来保存它们。确保你正在编辑的gui文件在你的mod中,否则它会将更改写入游戏文件夹。(要重置它们,请从Steam的属性窗口验证完整性) * 你可以通过拖动任何开发窗口来移动它们,并通过拖动边缘来调整它们的大小。 * 您可以在Outliner的层次结构中拖动UI元素来重新排序。右键单击以显示上下文菜单。 * 您可以在 "属性 "窗口中更改或添加新属性(通过单击加号)。 通过单击Outliner中的 "窗口",您可以打开另外两个窗口。UI组件和注册数据类型。 * gui/shared/standard.gui和gui/defaults.gui包含最常见的东西,如按钮、图标和文本。 * 注册数据类型可以用来查询游戏中显示数据的功能。 * 点击数据类型中的右上角按钮会将这些数据转储到你的日志文件夹(Documents/Paradox Interactive/CK3/logs)。你也可以使用 "DumpDataTypes "控制台命令。 注意:通常很容易误选一个模板,改变模板会影响UI中的''所有''实例。注意你在大纲中选择了什么文件。如果你在属性窗口中看到一个以 "type: "开头的蓝色标题,那就是一个模板,所以要注意不要编辑这部分内容(除非你打算编辑)。 == UI code == CK3’s UI is composed of containers and objects inside them. Most windows, for example, are created using a <code>window</code> container, while map icons use a widget or an hbox. The order in the file determines the order on the screen: what's lower in the code will appear on a higher layer. Most elements can also contain others, for example, there can be a textbox inside an icon inside a button. Nested elemenets, aka children, will will be moved with their parent. Position is set relative to the top left corner (either of the screen or the parent). This can be changed with <code>parentanchor</code> property. The available options are: left, right, top, bottom, hcenter (horizontal center) and vcenter (vertical center). They can be combined with a | like this: <code>parentanchor = right|vcenter</code>. Every element is opened and closed with curly brackets, like this: <code>container = { }</code>. The common code style is to open and close the block on the same level, while indenting the contents with one tab: <pre> widget = { size = { 50 50 } alpha = 0.5 } </pre> This helps you see the structure of the code better, notice any missing or extra brackets, and is needed for some editors to correctly fold the blocks of code. === UI Components === Window * The only movable container. To enable movement, add <code>movable = yes</code> property. * Can be fixed size or resized by its children. * In the game the background is set using templates, like <code>using = Window_Background</code> and <code>using = Window_Decoration</code>. * If a child is outside of a window, it won't be clickable and won't show a tooltip. Use <code>allow_outside = yes</code> to change this. <code>widget</code> * A static container. Similar to a window in other regards. <code>margin_widget</code> * Similar to a widget, but can be resized with margins. (This allows us to make windows that resize to screens of different size, by setting height to 100% and margins to ~50 to show the hud) <code>container</code> * Does not have a fixed size (but you can set maximumsize). * Resizes automatically to fit all its children, including invisible ones. Use <code>ignoreinvisible = yes</code> to ignore them. * Often used to group multiple elements to move them together. <code>flowcontainer</code> * Arranges all its children in a horizontal row. Use <code>direction = vertical</code> to make it vertical. * Doesn't ignore invisible children by default. Use <code>ignoreinvisible = yes</code> to change it. * Does not have a fixed size. * Its children cannot have positions, as they are set automatically. * If you need to adjust position of its child, you can put it inside a container or a widget and then change position relative to this parent. <code>hbox</code> <code>vbox</code> * Arranges all its children in a horizontal row and spreads them along its width. Vbox is the same but vertical. * Cannot have a fixed size, but instead takes the width of its parent as its own (ignoring the parent's margins). Vbox takes the height. ** If its parent can't have a fixed size (like flowcontainer), this may crash the game. * Can be limited by minimumsize/maximumsize and margins. * Ignores invisible children by default. Use <code>ignoreinvisible = no</code> to change this. * An hbox inside another hbox will have 0 size and won't spread its children. Use <code>layoutpolicy_horizontal = expanding</code> to resize it (or <code>layoutpolicy_vertical = expanding</code> in a vbox) * Accepts datamodels (to create lists from game data). <code>dynamicgridbox</code> * Is only used with datamodels. * Arranges all the items vertically. Use <code>flipdirection = yes</code> to make it horizontal. * Doesn't ignore invisible items by default. Use <code>ignoreinvisible = yes</code> to change it. * Can be fixed size, resized by the content and limited by minimumsize and maximumsize. * Items can be of different size. * Can become laggy with very long lists. <code>fixedgridbox</code> * Similar to a dynamic box but all its itmes are of fixed size (it's essentially a table). * Is only used with datamodels. * Arranges all its items vertically. Use <code>flipdirection = yes</code> to make it horizontal. * Cannot ignore invisible items. * Can be fixed size, resized by the content and limited by minimumsize and maximumsize. * Much better for performance with long lists. <code>overlappingitembox</code> * Is only used with datamodels. * Arranges all its items horizontally and overlaps them if the list is longer that the size of the box. Use <code>flipdirection = yes</code> to make it horizontal. * Can be fixed size or autoresized. <code>scrollarea</code> * A widget with scrollbars that appear if the content is bigger than its size. * Scrollbars can be disabled with <code>scrollbarpolicy_horizontal = always_off</code> and <code>scrollbarpolicy_vertical = always_off</code>. ** A scrollarea with no scrollbars can be used to crop lists or images. * Can be fixed size, resized by the content and limited by minimumsize and maximumsize. <code>button</code> * A clickable object. Accepts <code>onclick</code> and <code>onrightclick</code>. ** When adding a right click function, include <code>button_ignore = none</code>. * Doesn't have a texture by default. * Can be fixed size or resized by its children. ** A 0x0 button can be used to add invisible hotkeys. <code>icon</code> * Displays a texture. * Can be used as a widget to store children. * Can be flipped with <code>mirror = horizontal</code> or <code>mirror = vertical</code>. <code>textbox</code> * Shows text. * Can be fixed size or autoresized. * Use <code>elide = right</code> or <code>elide = left</code> to cut off text that is too long * Can be a single line or multiple, with <code>multiline = yes</code>. * Game files often use templates set in gui/shared/text.gui, like <code>text_single</code>. Use them to keep visual consistency and to type less code every time. === Promotes and Functions === Each window has a predefined set of commands - promotes and functions - available for it. These can be found in the data_types.log file in <code>Documents/Paradox Interactive/Crusader Kings III/logs/</code> after you use the <code>DumpDataTypes</code> console command. They are used to display all data from the game, like your name, gold, children, and to set button actions. A promote returns a scope, i.e a game object, like Character or Province, while a function returns a number, a string or a boolean (true/false) value, etc. Global commands can be used anywhere, like GetPlayer (returns the player character) or GetCurrentDate. Other commands can only be used in their window/object, for example, GetParents can only be used in the character window and must be started with <code>CharacterWindow.GetParents</code>. Commands can be chained like this: <code>CharacterWindow.GetCharacter.GetPrimaryTitle.GetHeir.GetPrimarySpouse.GetFather</code> Children can inherit the scope from their parent, meaning we wouldn't need to retype the line above to show information about this character. Instead we can set <code>datacontext</code> of a widget to this line and then every textbox in it will use <code>"[Character.GetNameNoTooltip]"</code>, <code>"[Character.GetGold]"</code>, etc. The same applies to items in gridboxes. === Templates === Templates are named blocks of code which can be used multiple times throughout the code, which helps maintain the same style and reduce the amount of code we write. Editing the template will edit all instances of it! Templates are global and can be defined in any file. Most of the game templates are stored in gui/shared. A local version, local_template, has to be defined within the same file. Templates can store the contents of an entire window or just one line, like this one: <pre> template Window_Size_Sidebar { size = { 610 100% } } </pre> This template can be used inside another element with "using = Window_Size_Sidebar", which will, essentially, replace the "using" line with the contents of the template. ==== Types ==== If templates can contain just a few properties, types are always whole elements, like a button or a widget. text_single and text_multi are types of a textbox with many properties already defined for them, so we don't need to retype them every time and instead simply write: <pre> text_single = { text = "my text" } </pre> Types are defined in a slightly different way, by creating a named group of types first: <pre> types Standard_Types { type text_single = textbox { ... } } </pre> ==== Blockoverride ==== Templates and types can have named override blocks, which allow us to edit a part of an instance without changing the whole template. For example, a template may have a default block of text: <pre> block "text" { text = "default_text" } </pre> To replace it, we add a blockoverride with the same name in our instance: <pre> blockoverride "text" { text = "actual text" } </pre> We can also remove it from our instance like this: <code>blockoverride "text" {}</code> == Scripted GUIs == Scripted guis are, essentially, hidden events triggered from the UI. The are stored as .txt files in game/common/scripted_guis and cannot be reloaded from the game, unlike the .gui files. The basic structure of a scripted gui is: <pre> gui_name = { scope = character # the root scope, i.e. the target of the effects saved_scopes = {} # any additional targets is_shown = {} # is it visible on the UI? ai_is_valid = {} # is the AI allowed to use it? Disabled by default. is_valid = {} # can the player use it? effect = { # what it does custom_tooltip = "" # adds a tooltip } } </pre> Not all of the blocks are necessary. Sometimes a scripted gui may only contain the scope and is_shown or effect. In the .gui file we use the following: <pre> datacontext = "[GetScriptedGui('gui_name')]" onclick = "[ScriptedGui.Execute( GuiScope.SetRoot( GetPlayer.MakeScope ).End)]" visible = "[ScriptedGui.IsShown( GuiScope.SetRoot( GetPlayer.MakeScope ).End)]" enabled = "[ScriptedGui.IsValid( GuiScope.SetRoot( GetPlayer.MakeScope ).End)]" tooltip = "[ScriptedGui.BuildTooltip( GuiScope.SetRoot( GetPlayer.MakeScope ).End)]" </pre> datacontext is necessary to link the element to the scripted gui. Other commands won't work without it. In this example the scripted gui is scoped to the player with a global function <code>GetPlayer.MakeScope</code>. It can be changed to someone in the character window, e.g. <code>CharacterWindow.GetCharacter.MakeScope</code>, or if the scope was a province, <code>HoldingView.GetProvince.MakeScope</code>. ScriptedGui.Execute is used with buttons and will execute everything listed in the <code>effect</code> block in the scripted gui. IsShown and IsValid check for conditions in is_shown and is_valid blocks. BuildTooltip can also be used with a textbox to display custom text in the UI. To save another scope to our scripted gui, we use AddScope like this: "[ScriptedGui.Execute( GuiScope.SetRoot( GetPlayer.MakeScope ).AddScope('target', CharacterWindow.GetCharacter.MakeScope ).End )]" And then we use the same name in the scripted gui: saved_scope = { target } Multiple scopes can be saved this way. It is important to not put any spaces before the dots or opening parentheses! <code>Execute(</code> is correct, <code>Execute (</code> is not. Other spaces can be omitted, but they help with readability. === Displaying a variable or script value === Variables and script values can be shown on the UI like this: variable: <code>text = "[GetPlayer.MakeScope.Var('test_var').GetValue|1]"</code> svalue: <code>text = "[GuiScope.SetRoot( GetPlayer.MakeScope ).ScriptValue('test_value')|0]"</code> In this example the variable is stored in the player character and is called test_var. Any other scope can be used, just remember to add MakeScope. |1 at the end is optional and will cut off all decimals save for one, so instead of 1.573 you will see 1.5. Note that it does not round the value. You can set this at any number, add % to convert to a percentage, add = or + to color the value if it's positive or negative. When using localization to display values in events, we use this: <code>event_var: "[ROOT.GetCharacter.MakeScope.Var('test_var').GetValue|0]"</code> <code>event_value: "[SCOPE.ScriptValue('test_value')|0]"</code> If you have a saved scope (named "target" here), it changes to this: <code>event_var: "[target.MakeScope.Var('test_var').GetValue|0]"</code> <code>event_value: "[GuiScope.SetRoot( target.MakeScope ).ScriptValue('test_value')|0]"</code> === Displaying data lists === We can create custom lists of characters, for example, to make societies. To do this, first, we need to add them to a variable list. This can be done though an event or a scripted gui, like this: <pre> effect = { every_living_character = { limit = { has_trait = paranoid } root = { add_to_variable_list = { name = secret_society target = prev } } } } </pre> If we fire this effect for the player, they will be the <code>root</code>, so the list will be stored in them. Then we use any list box (vbox, dynamicgridbox, fixedgridbox) with the datamodel set to our list: <pre> dynamicgridbox = { datamodel = "[GetPlayer.MakeScope.GetList('secret_society')]" item = { flowcontainer = { datacontext = "[Scope.GetCharacter]" portrait_head_small = {} text_single = { text = "[Character.GetNameNoTooltip]" } } } } </pre> == New windows and toggles == There isn't a simple way to create a new window and make your mod compatible with others. We have to either overwrite the hud or other windows. The usual way is to add the new window to hud.gui inside of ingame_topbar widget and then add a button to show/hide it. The alternative is to rewrite one of the unused windows, like test_gui and add a button with the console command that shows it. === Toggles with PdxGuiWidget === PdxGuiWidget is a simple function used to hide or reveal named elements. In this example we have a container with a hidden submenu, one button that shows it and another that hides it. # when clicked, the first button goes back to its parent, searches in it for the submenu and the other button, reveals them and hides itself # the second button searches for the element and the button, reveals them and hides itself <pre> container = { button = { name = "show submenu" onclick = "[PdxGuiWidget.AccessParent.FindChild('submnenu').Show]" onclick = "[PdxGuiWidget.AccessParent.FindChild('hide submenu').Show]" onclick = "[PdxGuiWidget.Hide]" } button = { name = "hide submenu" visible = no onclick = "[PdxGuiWidget.AccessParent.FindChild('submnenu').Hide]" onclick = "[PdxGuiWidget.AccessParent.FindChild('show submenu').Show]" onclick = "[PdxGuiWidget.Hide]" } widget = { name = "submenu" visible = no } } </pre> If the elements are separated by more parents/children, we can repeat AccessParent like this: onclick = "[PdxGuiWidget.AccessParent.AccessParent.AccessParent.AccessParent.FindChild('submnenu').Show]" Each button can hide or reveal multiple elements of any type. You only need to provide the name. Pros: * easy to edit on the fly as any changes can be reloaded with the "reload gui" command Cons: * the toggles will reset any time the game is restarted * If you want to hide multiple things or toggles, the code will get very bloated and hard to manage * trying to hide entries in a data list (like a dynamicgridbox) will only hide the first instance === Toggles with animation === We can set up animations that are triggered by buttons (or conditions) to hide/show elements or to even move them. This way we don't need to count how many parents separate the button and the window and we can trigger many things at once with just one onclick. The previous example would look like this and work the same way. The first button triggers "show_submenu", which hides the button and shows the rest, while the second button triggers "hide_submenu", which hides this button and the widget and shows the first button. <pre> container = { button = { state = { # this is an animation name = show_submenu on_start = "[PdxGuiWidget.Hide]" } state = { name = hide_submenu on_start = "[PdxGuiWidget.Show]" } onclick = "[PdxGuiTriggerAllAnimations('show_submenu')]" } button = { visible = no state = { name = show_submenu on_start = "[PdxGuiWidget.Show]" } state = { name = hide_submenu on_start = "[PdxGuiWidget.Hide]" } onclick = "[PdxGuiTriggerAllAnimations('hide_submenu')]" } widget = { visible = no state = { name = show_submenu on_start = "[PdxGuiWidget.Show]" } state = { name = hide_submenu on_start = "[PdxGuiWidget.Hide]" } } } </pre> it is longer, but animations can be saved as templates and reused with one line, like <code>using = hide_animation</code>. Fullscreen Barbershop uses animations extensively, if you want a better example. Pros: * can also be edited on the fly, with "reload gui" command * easier to link many things together, and even open a different window and trigger an animation in it Cons: * animation blocks can be quite lengthy * all toggles will reset when the game is restarted === Toggles with Scripted GUIs === Scripted guis allows us to use script to toggle visibility. They make it easier to manage multiple things but can impact performance when used in big numbers. For a scripted toggle we need to create a .txt file in common/scripted_guis/. The name of the file can be anything. A basic toggle in this file would looks like this: <pre> gui_toggle = { scope = character is_shown = { has_variable = gui_toggle } effect = { if = { limit = { has_variable = gui_toggle } remove_variable = gui_toggle } else = { set_variable = gui_toggle } } } </pre> When clicked, it adds a variable to the scoped character and removes it when clicked again. Then, if the variable is present, our window will be visible. If it's not, it's hidden. This is how the gui file would look like. We can use just one button as its function will change with each click. <pre> container = { button = { datacontext = "[GetScriptedGui('gui_toggle')]" onclick = "[ScriptedGui.Execute( GuiScope.SetRoot( GetPlayer.MakeScope ).End )]" } widget = { datacontext = "[GetScriptedGui('gui_toggle')]" visible = "[ScriptedGui.IsShown( GuiScope.SetRoot( GetPlayer.MakeScope ).End )]" } } </pre> "GetPlayer" is a global promote and returns the player character. "Player.MakeScope" makes our player the scope of the scripted gui, meaning this is where we store the variable in. Two buttons can be used if you want different tooltips for them. In this case, copy the 'visible' property to both buttons, but add 'Not' to one of them, so it's hidden by default: visible = "[Not(ScriptedGui.IsShown( GuiScope.SetRoot( GetPlayer.MakeScope ).End ))]" Pros: * the toggles are saved in the character and won't reset unless they die or you start a new game * easier to link many things, even in different windows The downsides: * you need to restart the game to update scripted guis * it's a little harder to remember the syntax (copy the code from here to reduce the chance of mistakes) {{Modding navbox}} [[Category:模组制作]] [[en:Interface]]
摘要:
请注意您对十字军之王3百科的所有贡献都被认为是在知识共享署名-非商业性使用-相同方式共享下发布,请查看在
十字军之王3百科:版权
的细节。如果您不希望您的文字被任意修改和再散布,请不要提交。
您同时也要向我们保证您所提交的内容是您自己所作,或得自一个不受版权保护或相似自由的来源。
未经许可,请勿提交受版权保护的作品!
为防止机器编辑,请完成下方验证
取消
编辑帮助
(在新窗口中打开)
Template:Clear
(
编辑
)
Template:Hover box
(
编辑
)
Template:Modding navbox
(
编辑
)
Template:Navbox
(
查看源代码
)(受保护)
Template:Navboxgroup
(
编辑
)
Template:Version
(
查看源代码
)(受保护)
Template:悬停
(
编辑
)
×
登录
密码
记住登录
加入十字军之王3百科
忘记密码?
其他方式登录
欢迎来到十字军之王3百科
人人皆可编辑,并且任何改进都有帮助。
感谢您帮助世界发现更多!
切换为可视化编辑器
开始编辑