2017-09-12 22:42:36 +02:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-07-06 10:08:05 +02:00
<class name= "EditorResourcePreviewGenerator" inherits= "RefCounted" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2017-09-12 22:42:36 +02:00
<brief_description >
Custom generator of previews.
</brief_description>
<description >
2019-06-22 01:04:47 +02:00
Custom code to generate previews. Please check [code]file_dialog/thumbnail_size[/code] in [EditorSettings] to find out the right size to do previews at.
2017-09-12 22:42:36 +02:00
</description>
<tutorials >
</tutorials>
<methods >
2021-08-22 03:52:44 +02:00
<method name= "_can_generate_small_preview" qualifiers= "virtual const" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
2019-05-20 10:45:12 +02:00
<description >
2021-05-15 23:48:59 +02:00
If this function returns [code]true[/code], the generator will call [method _generate] or [method _generate_from_path] for small previews as well.
2019-06-22 01:04:47 +02:00
By default, it returns [code]false[/code].
2019-05-20 10:45:12 +02:00
</description>
</method>
2021-08-22 03:52:44 +02:00
<method name= "_generate" qualifiers= "virtual const" >
2021-07-30 15:28:05 +02:00
<return type= "Texture2D" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "resource" type= "Resource" />
<param index= "1" name= "size" type= "Vector2i" />
2022-08-19 18:14:57 +02:00
<param index= "2" name= "metadata" type= "Dictionary" />
2017-09-12 22:42:36 +02:00
<description >
2018-09-21 09:33:05 +02:00
Generate a preview from a given resource with the specified size. This must always be implemented.
Returning an empty texture is an OK way to fail and let another generator take care.
Care must be taken because this function is always called from a thread (not the main thread).
2023-08-22 10:13:42 +02:00
[param metadata] dictionary can be modified to store file-specific metadata that can be used in [method EditorResourceTooltipPlugin._make_tooltip_for_path] (like image size, sample length etc.).
2017-09-12 22:42:36 +02:00
</description>
</method>
2021-08-22 03:52:44 +02:00
<method name= "_generate_from_path" qualifiers= "virtual const" >
2021-07-30 15:28:05 +02:00
<return type= "Texture2D" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "path" type= "String" />
<param index= "1" name= "size" type= "Vector2i" />
2022-08-19 18:14:57 +02:00
<param index= "2" name= "metadata" type= "Dictionary" />
2017-09-12 22:42:36 +02:00
<description >
2021-05-15 23:48:59 +02:00
Generate a preview directly from a path with the specified size. Implementing this is optional, as default code will load and call [method _generate].
2018-09-21 09:33:05 +02:00
Returning an empty texture is an OK way to fail and let another generator take care.
Care must be taken because this function is always called from a thread (not the main thread).
2023-08-22 10:13:42 +02:00
[param metadata] dictionary can be modified to store file-specific metadata that can be used in [method EditorResourceTooltipPlugin._make_tooltip_for_path] (like image size, sample length etc.).
2017-09-12 22:42:36 +02:00
</description>
</method>
2021-08-22 03:52:44 +02:00
<method name= "_generate_small_preview_automatically" qualifiers= "virtual const" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
2019-05-20 10:45:12 +02:00
<description >
2021-05-15 23:48:59 +02:00
If this function returns [code]true[/code], the generator will automatically generate the small previews from the normal preview texture generated by the methods [method _generate] or [method _generate_from_path].
2019-06-22 01:04:47 +02:00
By default, it returns [code]false[/code].
2019-05-20 10:45:12 +02:00
</description>
</method>
2021-08-22 03:52:44 +02:00
<method name= "_handles" qualifiers= "virtual const" >
2021-07-30 15:28:05 +02:00
<return type= "bool" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "type" type= "String" />
2017-09-12 22:42:36 +02:00
<description >
2022-08-12 18:07:53 +02:00
Returns [code]true[/code] if your generator supports the resource of type [param type].
2017-09-12 22:42:36 +02:00
</description>
</method>
</methods>
</class>