diff options
author | RĂ©mi Verschelde <rverschelde@gmail.com> | 2020-11-12 08:55:56 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-11-12 08:55:56 +0100 |
commit | 307ea716ccb4171a9b7e8693c4aab5a5751bf62f (patch) | |
tree | 8583421934bf7a920ba4a293af3e51df705df95b /editor | |
parent | a6d4484e57f54ac4570a4f6fa5a13f7bf4933004 (diff) | |
parent | 4cff322017ba76cde4889cc559cf436261f8b06c (diff) |
Merge pull request #43465 from fire/save-screenshot-master
Restore screenshot button.
Diffstat (limited to 'editor')
-rw-r--r-- | editor/editor_node.cpp | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/editor/editor_node.cpp b/editor/editor_node.cpp index d0d99e071a..c6613cdf63 100644 --- a/editor/editor_node.cpp +++ b/editor/editor_node.cpp @@ -2705,10 +2705,14 @@ void EditorNode::_screenshot(bool p_use_utc) { } void EditorNode::_save_screenshot(NodePath p_path) { - SubViewport *viewport = Object::cast_to<SubViewport>(EditorInterface::get_singleton()->get_editor_viewport()->get_viewport()); - viewport->set_clear_mode(SubViewport::CLEAR_MODE_ONLY_NEXT_FRAME); - Ref<Image> img = viewport->get_texture()->get_data(); - viewport->set_clear_mode(SubViewport::CLEAR_MODE_ALWAYS); + Control *editor_viewport = EditorInterface::get_singleton()->get_editor_viewport(); + ERR_FAIL_COND_MSG(!editor_viewport, "Cannot get editor viewport."); + Viewport *viewport = editor_viewport->get_viewport(); + ERR_FAIL_COND_MSG(!viewport, "Cannot get editor viewport."); + Ref<ViewportTexture> texture = viewport->get_texture(); + ERR_FAIL_COND_MSG(texture.is_null(), "Cannot get editor viewport texture."); + Ref<Image> img = texture->get_data(); + ERR_FAIL_COND_MSG(img.is_null(), "Cannot get editor viewport texture image."); Error error = img->save_png(p_path); ERR_FAIL_COND_MSG(error != OK, "Cannot save screenshot to file '" + p_path + "'."); } |