版本:Unity 6 (6000.0)
语言:英语
执行搜索
在 Unity 中工作

注册操作处理程序

您可以为搜索提供程序注册操作。用户可以通过搜索结果中的“更多选项”()图标访问已注册的操作。

注意:注册操作处理程序和注册搜索提供程序是不同的过程。您可以为现有的搜索提供程序注册新的操作处理程序。

要注册操作,您可以创建一个使用 SearchActionsProvider 属性标记的函数。此函数必须返回 IEnumerable<SearchAction>

以下示例显示了如何为资源搜索提供程序注册操作。

[SearchActionsProvider]
internal static IEnumerable<SearchAction> ActionHandlers()
{
    return new[]
    {
        new SearchAction("asset", "select", Icons.@goto, "Select asset...")
        {
            handler = (item, context) =>
            {
                var asset = AssetDatabase.LoadAssetAtPath<Object>(item.id);
                if (asset != null)
                {
                    Selection.activeObject = asset;
                    EditorGUIUtility.PingObject(asset);
                    EditorWindow.FocusWindowIfItsOpen(
                        Utils.GetProjectBrowserWindowType());
                }
            }
        },
        new SearchAction("asset", "open", SearchIcon.open, "Open asset... (Alt+Enter)")
        {
            handler = (item, context) =>
            {
                var asset = AssetDatabase.LoadAssetAtPath<Object>(item.id);
                if (asset != null)
                    AssetDatabase.OpenAsset(asset);
            }
        },
        new SearchAction("asset", "reveal", SearchIcon.folder, "Show in Explorer")
        {
            handler = (item, context) =>
            {
                EditorUtility.RevealInFinder(item.id);
            }
        }
    };
}

搜索操作

SearchAction 类描述了一个操作,并提供了一个处理程序来在特定 SearchItem 上执行该操作。

public class SearchAction
{
    public SearchAction(string providerType, string name,
                        Texture2D icon = null,
                        string tooltip = null);
    public ActionHandler handler;
    public EnabledHandler isEnabled;
}

providerType 是您为其注册操作的提供程序的唯一 ID。

ActionHandler 具有以下签名

// item: item that needs the action to be executed.
// context: search context of the SearchTool when the item is executed.
public delegate void ActionHandler(SearchItem item, SearchContext context);

您可以使用 isEnabled 谓词设置操作,该谓词确定操作是否可用于特定项目。

上下文搜索操作

要为搜索结果中特定类型的项目提供上下文(右键单击)操作,请为搜索提供程序注册名为 context 的操作。

以下示例来自资源搜索提供程序

new SearchAction(type, "context", null, "Context")
{
    handler = (item, context) =>
    {
        var asset = AssetDatabase.LoadAssetAtPath<Object>(item.id);
        if (asset != null)
        {
            Selection.activeObject = asset;
            EditorUtility.DisplayPopupMenu(
                QuickSearchTool.ContextualActionPosition,
                "Assets/", null);
        }
    }
}
执行搜索
在 Unity 中工作