2017-09-23 16:59:35 +08:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-07-06 16:08:05 +08:00
<class name= "EditorResourceConversionPlugin" inherits= "RefCounted" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2017-09-23 16:59:35 +08:00
<brief_description >
2023-01-15 04:02:34 +08:00
Plugin for adding custom converters from one resource format to another in the editor resource picker context menu; for example, converting a [StandardMaterial3D] to a [ShaderMaterial].
2017-09-23 16:59:35 +08:00
</brief_description>
<description >
2023-01-15 04:02:34 +08:00
[EditorResourceConversionPlugin] is invoked when the context menu is brought up for a resource in the editor inspector. Relevant conversion plugins will appear as menu options to convert the given resource to a target type.
Below shows an example of a basic plugin that will convert an [ImageTexture] to a [PortableCompressedTexture2D].
[codeblocks]
[gdscript]
extends EditorResourceConversionPlugin
2023-03-03 22:42:32 +08:00
func _handles(resource: Resource):
2023-01-15 04:02:34 +08:00
return resource is ImageTexture
func _converts_to():
return "PortableCompressedTexture2D"
2023-03-03 22:42:32 +08:00
func _convert(itex: Resource):
2023-01-15 04:02:34 +08:00
var ptex = PortableCompressedTexture2D.new()
ptex.create_from_image(itex.get_image(), PortableCompressedTexture2D.COMPRESSION_MODE_LOSSLESS)
return ptex
[/gdscript]
[/codeblocks]
To use an [EditorResourceConversionPlugin], register it using the [method EditorPlugin.add_resource_conversion_plugin] method first.
2017-09-23 16:59:35 +08:00
</description>
<tutorials >
</tutorials>
<methods >
2021-08-22 09:52:44 +08:00
<method name= "_convert" qualifiers= "virtual const" >
2021-07-30 21:28:05 +08:00
<return type= "Resource" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "resource" type= "Resource" />
2017-09-23 16:59:35 +08:00
<description >
2023-01-15 04:02:34 +08:00
Takes an input [Resource] and converts it to the type given in [method _converts_to]. The returned [Resource] is the result of the conversion, and the input [Resource] remains unchanged.
2017-09-23 16:59:35 +08:00
</description>
</method>
2021-08-22 09:52:44 +08:00
<method name= "_converts_to" qualifiers= "virtual const" >
2021-07-30 21:28:05 +08:00
<return type= "String" />
2017-09-23 16:59:35 +08:00
<description >
2023-01-15 04:02:34 +08:00
Returns the class name of the target type of [Resource] that this plugin converts source resources to.
2017-09-23 16:59:35 +08:00
</description>
</method>
2021-08-22 09:52:44 +08:00
<method name= "_handles" qualifiers= "virtual const" >
<return type= "bool" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "resource" type= "Resource" />
2021-08-22 09:52:44 +08:00
<description >
2023-01-15 04:02:34 +08:00
Called to determine whether a particular [Resource] can be converted to the target resource type by this plugin.
2021-08-22 09:52:44 +08:00
</description>
</method>
2017-09-23 16:59:35 +08:00
</methods>
</class>