您可以为搜索提供程序注册操作。用户可以通过搜索结果中的“更多选项”(⋮)图标访问已注册的操作。
注意:注册操作处理程序和注册搜索提供程序是不同的过程。您可以为现有的搜索提供程序注册新的操作处理程序。
要注册操作,您可以创建一个使用 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);
}
}
}