mirror of
https://github.com/bdunderscore/modular-avatar.git
synced 2025-04-04 11:39:03 +08:00
fix: showing menu contents of an expression menu throws an NRE (#1025)
Closes: #967
This commit is contained in:
parent
8ed649f9a4
commit
8be802bee5
@ -228,82 +228,8 @@ namespace nadena.dev.modular_avatar.core.editor
|
|||||||
|
|
||||||
_parameterGUI.DoGUI(true);
|
_parameterGUI.DoGUI(true);
|
||||||
|
|
||||||
var paramName = _parameterName.stringValue;
|
ShowInnateParameterGUI();
|
||||||
|
|
||||||
EditorGUILayout.BeginHorizontal();
|
|
||||||
|
|
||||||
bool? forceMixedValues = _parameterName.hasMultipleDifferentValues ? true : null;
|
|
||||||
var knownParameter = _parameterName.hasMultipleDifferentValues
|
|
||||||
? null
|
|
||||||
: _knownParameters.GetValueOrDefault(paramName);
|
|
||||||
|
|
||||||
var knownParamDefault = knownParameter?.DefaultValue;
|
|
||||||
var isDefaultByKnownParam =
|
|
||||||
knownParamDefault != null ? _value.floatValue == knownParamDefault : (bool?)null;
|
|
||||||
Object controller = knownParameter?.Source;
|
|
||||||
var controllerIsElsewhere = controller != null && !(controller is ModularAvatarMenuItem);
|
|
||||||
// If we can't figure out what to reference the parameter names to, disable the UI
|
|
||||||
controllerIsElsewhere = controllerIsElsewhere || _parameterSourceNotDetermined;
|
|
||||||
|
|
||||||
using (new EditorGUI.DisabledScope(
|
|
||||||
_parameterName.hasMultipleDifferentValues || controllerIsElsewhere)
|
|
||||||
)
|
|
||||||
{
|
|
||||||
// If we have multiple menu items selected, it probably doesn't make sense to make them all default.
|
|
||||||
// But, we do want to see if _any_ are default.
|
|
||||||
var anyIsDefault = _prop_isDefault.hasMultipleDifferentValues || _prop_isDefault.boolValue;
|
|
||||||
var multipleSelections = _obj.targetObjects.Length > 1;
|
|
||||||
var mixedIsDefault = multipleSelections && anyIsDefault;
|
|
||||||
using (new EditorGUI.DisabledScope(multipleSelections))
|
|
||||||
{
|
|
||||||
DrawHorizontalToggleProp(_prop_isDefault, G("menuitem.prop.is_default"), mixedIsDefault,
|
|
||||||
multipleSelections ? false : isDefaultByKnownParam);
|
|
||||||
}
|
|
||||||
GUILayout.FlexibleSpace();
|
|
||||||
|
|
||||||
var isSavedMixed = forceMixedValues ??
|
|
||||||
(_parameterName.hasMultipleDifferentValues || controllerIsElsewhere ? true : null);
|
|
||||||
DrawHorizontalToggleProp(_prop_isSaved, G("menuitem.prop.is_saved"), isSavedMixed);
|
|
||||||
GUILayout.FlexibleSpace();
|
|
||||||
DrawHorizontalToggleProp(_prop_isSynced, G("menuitem.prop.is_synced"), forceMixedValues,
|
|
||||||
knownParameter?.WantSynced);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (controllerIsElsewhere)
|
|
||||||
{
|
|
||||||
var refStyle = EditorStyles.toggle;
|
|
||||||
var refContent = new GUIContent("test");
|
|
||||||
var refRect = refStyle.CalcSize(refContent);
|
|
||||||
var height = refRect.y + EditorStyles.toggle.margin.top + EditorStyles.toggle.margin.bottom;
|
|
||||||
|
|
||||||
GUILayout.FlexibleSpace();
|
|
||||||
var style = new GUIStyle(EditorStyles.miniButton);
|
|
||||||
style.fixedWidth = 0;
|
|
||||||
style.fixedHeight = 0;
|
|
||||||
style.stretchHeight = true;
|
|
||||||
style.stretchWidth = true;
|
|
||||||
style.imagePosition = ImagePosition.ImageOnly;
|
|
||||||
var icon = EditorGUIUtility.FindTexture("d_Search Icon");
|
|
||||||
|
|
||||||
var rect = GUILayoutUtility.GetRect(new GUIContent(), style, GUILayout.ExpandWidth(false),
|
|
||||||
GUILayout.Width(height), GUILayout.Height(height));
|
|
||||||
|
|
||||||
if (GUI.Button(rect, new GUIContent(), style))
|
|
||||||
{
|
|
||||||
if (controller is VRCAvatarDescriptor desc) controller = desc.expressionParameters;
|
|
||||||
Selection.activeObject = controller;
|
|
||||||
EditorGUIUtility.PingObject(controller);
|
|
||||||
}
|
|
||||||
|
|
||||||
rect.xMin += 2;
|
|
||||||
rect.yMin += 2;
|
|
||||||
rect.xMax -= 2;
|
|
||||||
rect.yMax -= 2;
|
|
||||||
GUI.DrawTexture(rect, icon);
|
|
||||||
}
|
|
||||||
|
|
||||||
EditorGUILayout.EndHorizontal();
|
|
||||||
|
|
||||||
EditorGUILayout.EndVertical();
|
EditorGUILayout.EndVertical();
|
||||||
|
|
||||||
if (_texture != null)
|
if (_texture != null)
|
||||||
@ -497,6 +423,91 @@ namespace nadena.dev.modular_avatar.core.editor
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void ShowInnateParameterGUI()
|
||||||
|
{
|
||||||
|
if (_prop_isDefault == null)
|
||||||
|
// This is probably coming from a VRC Expressions menu asset.
|
||||||
|
// For now, don't show the UI in this case.
|
||||||
|
return;
|
||||||
|
|
||||||
|
var paramName = _parameterName.stringValue;
|
||||||
|
|
||||||
|
EditorGUILayout.BeginHorizontal();
|
||||||
|
|
||||||
|
bool? forceMixedValues = _parameterName.hasMultipleDifferentValues ? true : null;
|
||||||
|
var knownParameter = _parameterName.hasMultipleDifferentValues
|
||||||
|
? null
|
||||||
|
: _knownParameters.GetValueOrDefault(paramName);
|
||||||
|
|
||||||
|
var knownParamDefault = knownParameter?.DefaultValue;
|
||||||
|
var isDefaultByKnownParam =
|
||||||
|
knownParamDefault != null ? _value.floatValue == knownParamDefault : (bool?)null;
|
||||||
|
Object controller = knownParameter?.Source;
|
||||||
|
var controllerIsElsewhere = controller != null && !(controller is ModularAvatarMenuItem);
|
||||||
|
// If we can't figure out what to reference the parameter names to, disable the UI
|
||||||
|
controllerIsElsewhere = controllerIsElsewhere || _parameterSourceNotDetermined;
|
||||||
|
|
||||||
|
using (new EditorGUI.DisabledScope(
|
||||||
|
_parameterName.hasMultipleDifferentValues || controllerIsElsewhere)
|
||||||
|
)
|
||||||
|
{
|
||||||
|
// If we have multiple menu items selected, it probably doesn't make sense to make them all default.
|
||||||
|
// But, we do want to see if _any_ are default.
|
||||||
|
var anyIsDefault = _prop_isDefault.hasMultipleDifferentValues || _prop_isDefault.boolValue;
|
||||||
|
var multipleSelections = _obj.targetObjects.Length > 1;
|
||||||
|
var mixedIsDefault = multipleSelections && anyIsDefault;
|
||||||
|
using (new EditorGUI.DisabledScope(multipleSelections))
|
||||||
|
{
|
||||||
|
DrawHorizontalToggleProp(_prop_isDefault, G("menuitem.prop.is_default"), mixedIsDefault,
|
||||||
|
multipleSelections ? false : isDefaultByKnownParam);
|
||||||
|
}
|
||||||
|
|
||||||
|
GUILayout.FlexibleSpace();
|
||||||
|
|
||||||
|
var isSavedMixed = forceMixedValues ??
|
||||||
|
(_parameterName.hasMultipleDifferentValues || controllerIsElsewhere ? true : null);
|
||||||
|
DrawHorizontalToggleProp(_prop_isSaved, G("menuitem.prop.is_saved"), isSavedMixed);
|
||||||
|
GUILayout.FlexibleSpace();
|
||||||
|
DrawHorizontalToggleProp(_prop_isSynced, G("menuitem.prop.is_synced"), forceMixedValues,
|
||||||
|
knownParameter?.WantSynced);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (controllerIsElsewhere)
|
||||||
|
{
|
||||||
|
var refStyle = EditorStyles.toggle;
|
||||||
|
var refContent = new GUIContent("test");
|
||||||
|
var refRect = refStyle.CalcSize(refContent);
|
||||||
|
var height = refRect.y + EditorStyles.toggle.margin.top + EditorStyles.toggle.margin.bottom;
|
||||||
|
|
||||||
|
GUILayout.FlexibleSpace();
|
||||||
|
var style = new GUIStyle(EditorStyles.miniButton);
|
||||||
|
style.fixedWidth = 0;
|
||||||
|
style.fixedHeight = 0;
|
||||||
|
style.stretchHeight = true;
|
||||||
|
style.stretchWidth = true;
|
||||||
|
style.imagePosition = ImagePosition.ImageOnly;
|
||||||
|
var icon = EditorGUIUtility.FindTexture("d_Search Icon");
|
||||||
|
|
||||||
|
var rect = GUILayoutUtility.GetRect(new GUIContent(), style, GUILayout.ExpandWidth(false),
|
||||||
|
GUILayout.Width(height), GUILayout.Height(height));
|
||||||
|
|
||||||
|
if (GUI.Button(rect, new GUIContent(), style))
|
||||||
|
{
|
||||||
|
if (controller is VRCAvatarDescriptor desc) controller = desc.expressionParameters;
|
||||||
|
Selection.activeObject = controller;
|
||||||
|
EditorGUIUtility.PingObject(controller);
|
||||||
|
}
|
||||||
|
|
||||||
|
rect.xMin += 2;
|
||||||
|
rect.yMin += 2;
|
||||||
|
rect.xMax -= 2;
|
||||||
|
rect.yMax -= 2;
|
||||||
|
GUI.DrawTexture(rect, icon);
|
||||||
|
}
|
||||||
|
|
||||||
|
EditorGUILayout.EndHorizontal();
|
||||||
|
}
|
||||||
|
|
||||||
private void EnsureLabelCount(int i)
|
private void EnsureLabelCount(int i)
|
||||||
{
|
{
|
||||||
if (_labels == null || _labelsRoot.arraySize < i || _labels.Length < i)
|
if (_labels == null || _labelsRoot.arraySize < i || _labels.Length < i)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user