-
Notifications
You must be signed in to change notification settings - Fork 25
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
BlockCanvas: Implement drag & drop the file from resource FileSystem #305
Conversation
This depends on #296. So, set it as draft now. |
Here is the demo video: Screencast.From.2024-11-05.16-28-04.mp4 |
a5ce51c
to
c838758
Compare
c838758
to
d9f104a
Compare
Define the format "{const <parameter name>: <type>}" as constant parameter value. And, it is a kind of in parameter value, but never changes. https://phabricator.endlessm.com/T35712
d9f104a
to
714c31f
Compare
Here is the latest demo video: Screencast.From.2024-11-19.19-40-13.mp4 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm leaving some nits. Good work!
if file_path == "": | ||
return null | ||
|
||
var file_name = file_path.get_file() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a chance that this string doesn't have a valid file? Eg. what would happen if the user removes the file from the filesystem? In that case what does get_file()
return?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
get_file()
simply returns the file name part of the "string". Fixed in the new commit which checks with FileAccess.file_exists()
and ResourceLoader.exists()
.
# const_parameter is a kind of in_parameter with default value, but never | ||
# changes value. | ||
var parameter_const := _append_input_parameter(parameter, id) | ||
parameter_const.visible = false |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What does this do exactly? I want to make sure the extra syntax is really worth it since it seems like the regular input parameter would work fine.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This clears the in parameter's "visible" to avoid modify the value from users.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also, if the in parameter shows up, it displays the full file path as a long text.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Have get_resource_block_definition() providing resource block's definition. It uses constant parameter value with key "file_path" to hold the resource file's path information. https://phabricator.endlessm.com/T35712
… dock Dragging the resources from the filesystem dock shows the object's type as "files". So, allow the "files" type in _can_drop_data() and handle it in _drop_data(). Then, implement getting the resource's file path as a Variable block with _drop_files() in detail. And, because Godot allows dragging multiple files at the same time, this implemention parses the "files"' paths, then generates the corresponding block definition with get_resource_block_definition() and sets default "file_path" for each file's path. Besides, to avoid the dropped blocks overlap with each others on the canvas, each block biases its position a little bit automatically. https://phabricator.endlessm.com/T35712
…ile blocks Drag & drop resouce files as blocks into canvas has been implemented. This commit focuses on serializing from the resource file blocks to AST nodes and values. The resource file's path is saved as in the arguments "file_path" feild. So, pass the arguments, which may have "file_path" into get_block_definition() to rebuild resource file's block definition. https://phabricator.endlessm.com/T35712
714c31f
to
96a7da3
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Excellent!
Add how to drag & drop a resource file as getter block from the Resource Filesystem dock. This follows #305. https://phabricator.endlessm.com/T35712
Dragging the files from resource FileSystem shows the files' type as
"files". So, allow the "files" type in _can_drop_data() and handle it in
_drop_data(). Then, implement getting the files' resource paths as
Variable blocks with _drop_files() in detail.
https://phabricator.endlessm.com/T35712