版本

menu_open
Wwise SDK 2019.1.11
Wwise 插件对话框参考文档

插件对话框资源 中所说,插件 DLL 必须包含当用户编辑插件属性时 Wwise 中所显示的对话框的资源。这同时适用于源插件和效果器插件。

本节专门介绍有关这些对话框资源的详情,例如对话框的要求尺寸、如何在对话框中加入各种控件以及如何将这些控件绑定到插件属性。

如何为插件创建对话框资源

在 Microsoft 开发环境中,使用对话框编辑器将对话框资源添加到 Wwise 插件 DLL 工程中。然后您可以使用 Toolbox(工具箱)窗口的 Dialog Editor(对话框编辑器)部分中的工具添加控件。

对话框尺寸

Effect plug-in(效果器插件)可在 Wwise 中通过 Effect Editor 的 Effect Settings 选项卡编辑。Source plug-in(源插件)既可在 Contents Editor 中编辑,也可在 Property Editor 中编辑。

Effect Editor 和 Property Editor 中显示的对话框可能很大,而 Contents Editor 中显示的对话框受到限制,尺寸较小,以便能轻松地融入视图中。

备注:对话框相关代码 中所述,AK::Wwise::IAudioPlugin::GetDialog() 和 AK::Wwise::IAudioPlugin::WindowProc() 应检查 AK::Wwise::IAudioPlugin::eDialog 参数以了解调用的是哪个对话框。

Property Editor 和 Effect Editor 对话框的尺寸

源插件的 Property Editor 对话框和效果器插件的 Effect Editor 对话框最大宽度应该为 525 个对话框单位,最大高度应该为 325 个单位。

注意: 对话框如果太大会被裁剪,用户可能无法看到全部控件。
技巧: 在 Microsoft 开发环境对话框编辑器中选中您的对话框时,状态栏最右侧会显示对话框的尺寸,以对话框单位表示。

Content Editor对话框的尺寸

对于源插件,Content Editor 对话框最大宽度应为 194 个对话框单位,高度正好为 13 个单元。

注意: 对话框如果太大会被裁剪,用户可能无法看到全部控件。
技巧: 在 Microsoft 开发环境对话框编辑器中选中您的对话框时,状态栏最右侧会显示对话框的尺寸,以对话框单位表示。

利用Wwise检索对话框资源

请参阅 对话框相关代码 了解有关 AK::Wwise::IAudioPlugin::GetResourceHandle()和AK::Wwise::IAudioPlugin::GetDialog() 的信息,它们是您查找对话框资源而必须为 Wwise 实现的功能。

如何向对话框中添加常规控件

您可以直接在 Microsoft 开发环境 Dialog Editor 中使用 Toolbox 的 Dialog Editor 版块的相应工具添加常规控件,例如静态控件、编辑控件、复选框、按钮、单选按钮和组合控件。Wwise 将自动细分这些控件,使它们与应用程序中其他位置的相似控件有相同的外观。

备注: 一个明显的例外是下拉框/组合框控件不会自动细分。如果您在对话框中需要下拉控件,则应使用 Combo 自定义控件。请参阅 “Class”控件属性 了解详情。
备注: 当属性支持 RTPC 时,将自动显示控件绑定到该属性的 RTPC 小组件。请参阅 属性要素 了解有关如何对属性启用 RTPC 的详情。

如何将常规控件绑定到属性

复选框和单选按钮可关联到您的插件属性,以便它们在用户操作控件时进行更新(反之亦然),而无需您添加更多代码。

为此,必须使用 include/AK/Wwise/Utilities.h 中定义的宏来创建“填充表”:

AK_BEGIN_POPULATE_TABLE(ToneGenProp)
AK_POP_ITEM(IDC_CHECK_SWEEPFREQ, szSweepFreq)
AK_POP_ITEM(IDC_RADIO_FREQSWEEPLIN, szSweepFreqType)
(... insert other items here...)
AK_END_POPULATE_TABLE()

从AK_BEGIN_POPULATE_TABLE() 宏入手,它有一个参数,即表格的标识符。该标识符必须是一个有效的 C++ 标识符,在其所属范围内不能有重名。它是您在 AK::Wwise::IAudioPlugin::GetDialog() 中设置填充表 out 参数时将使用的同一标识符(请参阅 对话框相关代码 了解详情)。

然后您使用 AK_POP_ITEM() 宏将控件关联到属性(必须绑定到属性的各个控件需要在表格中具有 AK_POP_ITEM() 条目)。此宏的第一个参数是对话框中控件的 ID。第二个参数是与插件 XML 定义文件中的定义一致的属性名称(请参阅 属性要素 了解有关属性名称的详情)。

复选框可以关联到bool 类型的属性。属性值true 代表控件已被选定,而属性值false 代表控件没有被选定。

单选按钮可关联到int32 类型的属性。控件组中的各个单选按钮对应于一个特定值。组中的第一个单选按钮对应于值 0,第二个对应于值 1,第三个对应于 2,以此类推。要使单选按钮正常工作,必须小心设置两个属性:单选按钮的Tab键顺序和控件组。

要在 Microsoft 开发环境对话框编辑器中编辑对话框时查看 Tab 键顺序,打开 Format 菜单,然后选择 Tab Order。各个控件旁边会出现对应于 Tab 键顺序的编号。要更改顺序,单击应设为第一的控件,然后是应设为第二的控件,以此类推,直至按需要设置好所有控件的顺序。完成后,返回 Format 菜单,并重新选择 Tab Order 以关闭该选项。

要将控件组合在一起,在 Microsoft 开发环境的 Properties 窗口中将第一个单选按钮的Group 属性设为True 。将该组其他单选按钮的Group 属性设为False

请参阅 Microsoft 开发环境文档了解有关 Tab 键顺序、控件组和对话框编辑器的更多一般信息。

在定义所有 AK_POP_ITEM() 条目后,使用 AK_END_POPULATE_TABLE() 宏结束填充表的声明。

技巧: 您可以将此声明放置在 AK::Wwise::IAudioPlugin::GetDialog() 的同一 CPP 文件夹中,它是您唯一需要访问的位置。

如何向对话框中添加 Wwise 属性控件

要将 Wwise 对话框控件(例如标题 、滑块和推子)集成到对话框中,使用标题文本经过特殊编码的静态文本控件占位符。此文本需要具有以下格式:

Class=[Classname];Prop=[Propname];[Attribute1]=[Value1];[Attribute2]=[Value2];[...]
技巧: 为了更加便于查看对话框控件的布局,可在 Microsoft 开发环境对话框编辑器中将静态占位符属性的Border 设为True 。请参阅 示例 了解示例。
备注: 当属性支持 RTPC 时,将自动显示控件绑定到该属性的 RTPC 小组件。请参阅 属性要素 了解有关如何对属性启用 RTPC 的详情。

下面我们将详细地查看这些属性:

“Class”控件属性

Class 属性是必备的。它用于标识将插入对话框中来替换静态占位符的控件类型。此属性采用以下格式:

Class=[Classname]

其中[Classname]可以是以下某一个:

  • Caption :只读文本显示

    资源中的静态控件高度应正好为 13 个单位,宽度足以容纳它可能包含的最长文本。

  • Combo :下拉列表

    资源中的静态控件高度应正好为 13 个单位,宽度足以容纳它可能包含的最长文本。

  • Edit :可编辑的文本

    资源中的静态控件高度应正好为 13 个单位,宽度足以容纳它可能包含的最长文本。“字符串”类型的属性应绑定到此控件。

  • Fader :音量推子


  • Spinner :带微调控件的整型数值编辑器

    资源中的静态控件高度应正好为 13 个单位,宽度足以容纳它可能包含的最大值。

  • SuperRange :带横向滑块的数值编辑器

    资源中的静态控件高度应正好为 13 个单位,宽度足以容纳它可能包含的最大值。
备注: 其中各个控件支持各种可选属性,以调整它们的行为来满足各个属性的特定需求。请参阅 其他控件属性 了解详情。

“Prop”控件属性

Prop 属性可让您将控件绑定到插件属性之一。此属性采用以下格式:

Prop=[Propname]

其中[PropName]指定该控件应该绑定到的属性的名称。该名称为插件 XML 定义文件中的指定名称(请参阅 属性要素 了解详情)。

此属性为可选。如果不指定此属性,则仍会创建此控件,但它不会绑定到某个属性。例如您可以使用Caption 控件来显示您使用SetWindowText() 在控件上设置的某个文本。

注意: 绑定到属性的控件可以根据其属性值来显示文本。绝对不要在这些控件上具体设置窗口文本。
注意: 在创建 绑定到属性的控件时,确保保留控件文本原样,直至完全创建 对话框。如果更改控件文本过早,例如在 AK::Wwise::IAudioPlugin::WindowProc() 中处理WM_INITDIALOG 消息,资源文本中设置的Class 属性在需要时则将不可用,Wwise 无法创建相应的控件。

其他控件属性

除上述ClassProp 属性外,某些控件还支持其他其他属性,这些属性可让您微调控件来满足各个属性的需求。

小数点位数

格式:

Decimals=[Number]

其中 [Number] 是小数点后显示的位数。此值必须是非负整数。如果设为 0,则不会显示小数和小数点。

当以下类型的控件绑定到数值属性时,可对这些控件使用此属性:

  • Caption
  • Fader
  • SuperRange
警告: 此属性将会废除。必须在插件描述 XML 中的 /PluginModule/{EffectPlugin or SourcePlugin}/Properties/Property/UserInterface[Decimals] 处定义它。请参阅 UserInterface 了解详情。

分钟

格式:

Min=[Number]

其中[Number]是在此控件中可以输入的最小值。此值可以是整数或小数,具体取决于控件所绑定的属性类型。

当以下类型的控件绑定到数值属性时,可对这些控件使用此属性:

  • Fader
  • SuperRange
警告: 此属性将会废除。必须在 /PluginModule/{EffectPlugin 或 SourcePlugin}/Properties/Property/Restrictions/ValueRestriction/Range/Min 处的插件描述 XML 中定义它。请参阅 UserInterface 了解详情。

最大值

格式:

Max=[Number]

其中 [Number] 是此控件中可以输入的最大值。此值可以是整数或小数,具体取决于控件所绑定的属性类型。

当以下类型的控件绑定到数值属性时,可对这些控件使用此属性:

  • Fader
  • SuperRange
警告: 此属性将会废除。必须在 /PluginModule/{EffectPlugin or SourcePlugin}/Properties/Property/Restrictions/ValueRestriction/Range/Max 处的插件描述 XML 中定义它。请参阅 UserInterface 了解详情。

中值

格式:

Mid=[Number]

其中[Number]是显示在SuperRange 控件底部的小滑块的锚固点。此值可以是整数或小数,具体取决于控件所绑定的属性类型。

此属性可以用于以下类型的控件:

  • SuperRange
警告: 此属性将会废除。必须在 /PluginModule/{EffectPlugin or SourcePlugin}/Properties/Property/UserInterface[Mid] 处的插件描述 XML 中定义它。请参阅 UserInterface 了解详情。

步长

格式:

Step=[Number]

其中 [Number] 是移动滑块时的数值变化量。此值可以是整数或小数,具体取决于控件所绑定的属性类型。

当以下类型的控件绑定到数值属性时,可对这些控件使用此属性:

  • Fader
  • SuperRange
警告: 此属性将会废除。必须在 /PluginModule/{EffectPlugin or SourcePlugin}/Properties/Property/UserInterface[Step] 处的插件描述 XML 中定义它。请参阅 UserInterface 了解详情。

微调

格式:

Fine=[Number]

其中 [Number] 是在按住 SHIFT 键的同时移动滑块而发生的数值变化量。此值可以是整数或小数,具体取决于控件所绑定的属性类型。

当以下类型的控件绑定到数值属性时,可对这些控件使用此属性:

  • Fader
  • SuperRange
警告: 此属性将会废除。必须在 /PluginModule/{EffectPlugin or SourcePlugin}/Properties/Property/UserInterface[Fine] 处的插件描述 XML 中定义它。请参阅 UserInterface 了解详情。

UIMin

格式:

UIMin=[Number]

其中 [Number] 是通过使用滑块初始可设置的最小值。如果此值大于使用Min 属性设置的值,则用户可通过输入一个小于此属性指定值的值来强制将它设为更小值,从而扩大控制范围。

此值可以是整数或小数,具体取决于控件所绑定的属性类型。

技巧: 此属性的目的是使控件滑块的初始值域更加适用于属性值域非常大的情形。如果某个属性具有较大的理论范围,但用户一般使用较小的范围,则使用 Min/Max 属性设置 实际范围,并使用 UIMin/UIMax 属性设置滑块的初始范围。

当以下类型的控件绑定到数值属性时,可对这些控件使用此属性:

  • SuperRange
警告: 此属性将会废除。必须在 /PluginModule/{EffectPlugin或SourcePlugin}/Properties/Property/UserInterface[UIMin] 处插件描述 XML 中定义它。请参阅 UserInterface 了解详情。

UIMax

格式:

UIMax=[Number]

其中 [Number] 是通过使用滑块初始可设置的最大值。如果此值小于使用Max 属性指定的值,则用户可通过输入一个比此属性指定值更大的值来强制将它设为更大值,从而扩大控制范围。

此值可以是整数或小数,具体取决于控件所绑定的属性类型。

技巧: 此属性的目的是使控件滑块的初始值域更加适用于属性值域非常大的情形。如果某个属性具有较大的理论范围,但用户一般使用较小的范围,则使用 Min/Max 属性设置 实际范围,并使用 UIMin/UIMax 属性设置滑块的初始范围。

当以下类型的控件绑定到数值属性时,可对这些控件使用此属性:

  • SuperRange
警告: 此属性将会废除。必须在 /PluginModule/{EffectPlugin or SourcePlugin}/Properties/Property/UserInterface[UIMax] 处的插件描述 XML 中定义。请参阅 UserInterface 了解详情。

选项

格式:

Options=[Value1]:[Text1],[Value2]:[Text2],...,[ValueN]:[TextN]

其中 [ValueX] 是数值属性的一个可能值,[TextX] 是控件中与该值相关联的文本。此字符串包含多对“value:text”,各对之间用逗号隔开,每对中包含一个数值和用冒号隔开的相关文本。例如:

  • 布尔值属性:"0:Off,1:On"
  • 视为枚举的数值属性:"0:Low Pass,1:High Pass,2:Band Pass"
备注: 对于bool 属性,值/文本组的值一侧使用0代表 false ,1代表 true

此属性可以用于以下类型的控件:

  • Combo

它用于定义下拉列表的内容。Wwise用户使用Combo 控件只可设置Options 属性中的值。

备注: Options 属性的格式与AK::Wwise::IAudioPlugin::DisplayNamesForPropValues() 方法的格式相同。请参阅 用户可见的属性名称和属性值 了解详情。
警告: 此属性将会废除。必须在 /PluginModule/{EffectPlugin or SourcePlugin}/Properties/Property/Restrictions/ValueRestriction/Enumeration/Value[DisplayName] 处的插件描述 XML 中为各个枚举值定义这些选项。请参阅 UserInterface 了解详情。

滑块类型

格式:

SliderType=[integer value]

请参阅 UserInterface 了解 SliderType 值

当以下类型的控件绑定到数值属性时,可对这些控件使用此属性:

  • Fader
  • SuperRange
警告: 此属性将会废除。必须在 /PluginModule/{EffectPlugin or SourcePlugin}/Properties/Property/UserInterface[SliderType] 处的插件描述 XML 中定义它。请参阅 UserInterface 了解详情。

对齐

格式:

Align=[Left|Center|Right]

此属性可用于以下类型的控件:

  • Caption
  • Edit

它用于对齐控件显示的文件。

FontSize

格式:

FontSize=[0|1]

其中数字代表:

  • 0(默认值):标准字体
  • 1:大字体

此属性可以用于以下类型的控件:

  • Caption

它用于指定控件所显示文本的字体大小。

TimeDisplay

格式:

TimeDisplay=[0|1|2]

其中数字代表:

  • 0(默认值):无特殊时间格式。
  • 1:使用 MM:SS.mmm(分钟、秒钟、毫秒)格式。最小值为 -59:59.999,最大值为 59:59.999。
  • 2:使用 HH:MM:SS.mmm(小时、分钟、秒钟、毫秒)格式。在这种情况下无最小值或最大值。

当以下类型的控件绑定到代表毫秒的int32 类型属性时,此属性可用于这些控件:

  • Caption

请参阅 属性要素 了解有关属性类型的详情。

示例

以下是 Microsoft 开发环境对话框编辑器中所示的效果器插件对话框资源示例:

以下是对话框资源代码,准确地显示了用于对话框中各种静态止位符的标题文本:

IDD_MYPLUGIN DIALOGEX 0, 0, 217, 187
STYLE DS_SETFONT | DS_FIXEDSYS | WS_CHILD
FONT 8, "MS Shell Dlg", 0, 0, 0x0
BEGIN
LTEXT "Class=Caption;Prop=Name",IDC_NAME,8,8,78,13,WS_BORDER
LTEXT "Class=Caption;Prop=Duration;Align=1;TimeDisplay=1;FontSize=1",
IDC_DURATION,90,8,78,13,WS_BORDER
LTEXT "Class=Caption;Prop=OutputLevel;Align=2;Decimals=1",
IDC_OUTPUTLEVEL_CAPTION,172,8,36,13,WS_BORDER
LTEXT "Class=Caption",IDC_CUSTOM_CAPTION,8,24,200,13,WS_BORDER
CONTROL "Enable Feedback",IDC_CHECK_FEEDBACKENABLED,"Button",
BS_AUTOCHECKBOX | WS_TABSTOP,8,46,70,10
LTEXT "Feedback",IDC_STATIC_FEEDBACK,19,62,32,8
LTEXT "Class=SuperRange;Prop=Feedback;Min=0;Mid=0;Max=100;UIMin=0;UIMax=10;Step=0.5;Fine=0.1;Decimals=1",
IDC_RANGE_FEEDBACK,58,60,60,13,WS_BORDER
LTEXT "Interpolation:",IDC_INTERPOLATION_STATIC,8,86,45,8
CONTROL "Linear",IDC_RADIO_LINEAR,"Button",BS_AUTORADIOBUTTON |
WS_GROUP,11,97,35,10
CONTROL "Logarithmic",IDC_RADIO_LOG,"Button",BS_AUTORADIOBUTTON,
11,108,54,9
LTEXT "Loop count",IDC_STATIC,8,132,36,8
LTEXT "Class=Spinner;Prop=LoopCount;Min=1;Max=32767",
IDC_LOOP_COUNT_SPINNER,53,129,65,13,WS_BORDER
LTEXT "Type",IDC_STATIC,8,164,17,8
LTEXT "Class=Combo;Prop=WaveType;Options=0:Sine,1:Triangular,2:Square,3:Sawtooth,4:White Noise,5:Pink Noise",
IDC_COMBO_WAVETYPE,34,161,84,13,WS_BORDER | WS_TABSTOP
LTEXT "Class=Fader;SliderType=1;Prop=OutputLevel;Min=-96.3;Max=0;Decimals=2",
IDC_LEVEL_FADER,167,43,37,124,WS_BORDER
CTEXT "OutputLevel",IDC_VOLUME_STATIC,161,171,48,8,
SS_CENTERIMAGE
END
警告: 此代码示例中的某些属性将会废除:Decimals、Step、Fine、SliderType、Mid、UIMin、UIMax。请参阅 UserInterface 了解详情。

在此例中,Enable Feedback 复选框和 Interpolation 单选按钮需要绑定到属性,因此插件的.cpp文件定义了下表,此表由插件的 AK::Wwise::IAudioPlugin::GetDialog() 返回:

static LPCWSTR szFeedbackEnabled = L"FeedbackEnabled";
static LPCWSTR szInterpolation = L"Interpolation";
// 没有将静态文本 UI 控件绑定到属性上
AK_BEGIN_POPULATE_TABLE(MyPopTable)
AK_POP_ITEM(IDC_CHECK_FEEDBACKENABLED, szFeedbackEnabled)
AK_POP_ITEM(IDC_RADIO_LINEAR, szInterpolation)
AK_END_POPULATE_TABLE()
(...)
bool MyPlugin::GetDialog( eDialog in_eDialog, UINT & out_uiDialogID, PopulateTableItem *& out_pTable ) const
{
out_uiDialogID = IDD_DELAY_BIG;
out_pTable = MyPopTable;
return true;
}

最后,下面是 Wwise 用户在 Effect Editor 中可见到的对话框:

测试插件对话框

Effect Editor 对话框(仅限于效果器插件)

要在 Wwise 中查看对话框:

  1. 访问 Views 菜单,并选择 Effect Editor
  2. 在 Effect 下拉列表中,选择您的效果器插件。如果插件没有出现在列表中,则请参阅 Wwise 源插件和效果器插件故障排除指南

效果器插件的对话框现在应已显示在 Effect Editor 中了。请参阅 Wwise 文档了解有关效果器用法的详情。

Contents Editor 对话框(仅限源插件)

要在 Wwise 中查看对话框:

  1. 右键单击 Actor-Mixer Hierarchy,然后选择 New Child > Sound SFX。此操作将创建新的声音。
  2. 双击新声音以检查它
  3. 在Contents Editor 中,单击 Add Source 按钮并在列表中选择您的插件。如果插件没有出现在列表中,则请参阅 Wwise 源插件和效果器插件故障排除指南

源插件的对话框现在应已显示在 Contents Editor 中。

Property Editor 对话框(仅限于源插件)

要在 Wwise 中查看对话框:

  1. 右键单击 Actor-Mixer Hierarchy,然后选择 New Child > Sound SFX。此操作将创建新的声音。
  2. 双击新声音以检查它。
  3. 在Contents Editor 中,单击 Add Source 按钮并在列表中选择您的插件。如果插件没有出现在列表中,则请参阅 Wwise 源插件和效果器插件故障排除指南
  4. 双击针对您的插件所显示的小对话框。

Property Editor 现在应已显示您的插件对话框。

故障排除

如果遇到任何问题,请参见 Wwise 源插件和效果器插件故障排除指南 中的帮助。

参见
对话框相关代码
插件对话框资源
属性要素
用户可见的属性名称和属性值
AkForceInline void Max(AkReal32 *in_pVolumesDst, const AkReal32 *in_pVolumesSrc, AkUInt32 in_uNumChannels)
Get max for all elements of two volume vectors, independently.
AkForceInline void Min(AkReal32 *in_pVolumesDst, const AkReal32 *in_pVolumesSrc, AkUInt32 in_uNumChannels)
Get min for all elements of two volume vectors, independently.

此页面对您是否有帮助?

需要技术支持?

仍有疑问?或者问题?需要更多信息?欢迎联系我们,我们可以提供帮助!

查看我们的“技术支持”页面

介绍一下自己的项目。我们会竭力为您提供帮助。

来注册自己的项目,我们帮您快速入门,不带任何附加条件!

开始 Wwise 之旅