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