Set up proper drawing for RectViewNode. it grabs the required parameters from new methods in WorldGenBaseResource.

This commit is contained in:
Relintai 2021-12-26 00:03:17 +01:00
parent 61b66b4109
commit 829b01b72f
3 changed files with 44 additions and 5 deletions

View File

@ -21,6 +21,21 @@ func set_content(arr : Array) -> void:
func add_content(item_name : String = "") -> void: func add_content(item_name : String = "") -> void:
pass pass
func get_editor_rect_border_color() -> Color:
return Color(1, 1, 1, 1)
func get_editor_rect_color() -> Color:
return Color(0.8, 0.8, 0.8, 0.9)
func get_editor_rect_border_size() -> int:
return 2
func get_editor_font_color() -> Color:
return Color(0, 0, 0, 1)
func get_editor_additional_text() -> String:
return "WorldGenBaseResource"
func setup_property_inspector(inspector) -> void: func setup_property_inspector(inspector) -> void:
inspector.add_slot_line_edit("get_name", "set_name", "Name") inspector.add_slot_line_edit("get_name", "set_name", "Name")
inspector.add_slot_rect2("get_rect", "set_rect", "Rect", 1) inspector.add_slot_rect2("get_rect", "set_rect", "Rect", 1)

View File

@ -27,14 +27,14 @@ subzones = [ SubResource( 14 ), SubResource( 15 ) ]
[sub_resource type="Resource" id=13] [sub_resource type="Resource" id=13]
resource_name = "qqq" resource_name = "qqq"
script = ExtResource( 3 ) script = ExtResource( 3 )
rect = Rect2( 0, 0, 200.4, 61.8 ) rect = Rect2( 14, 9, 200.4, 61.8 )
locked = false locked = false
subzones = [ ] subzones = [ ]
[sub_resource type="Resource" id=1] [sub_resource type="Resource" id=1]
resource_name = "wwww" resource_name = "wwww"
script = ExtResource( 2 ) script = ExtResource( 2 )
rect = Rect2( 133, 63, 224, 158 ) rect = Rect2( 161, 40, 241, 158 )
locked = false locked = false
zones = [ SubResource( 8 ), SubResource( 13 ) ] zones = [ SubResource( 8 ), SubResource( 13 ) ]
@ -104,7 +104,7 @@ subzones = [ ]
[sub_resource type="Resource" id=7] [sub_resource type="Resource" id=7]
resource_name = "343" resource_name = "343"
script = ExtResource( 2 ) script = ExtResource( 2 )
rect = Rect2( 14, 134, 157, 152 ) rect = Rect2( 26, 21, 154, 114 )
locked = false locked = false
zones = [ SubResource( 12 ) ] zones = [ SubResource( 12 ) ]

View File

@ -12,12 +12,29 @@ enum DragType {
var edited_resource : WorldGenBaseResource = null var edited_resource : WorldGenBaseResource = null
var _edited_resource_rect_border_color : Color = Color(1, 1, 1, 1)
var _edited_resource_rect_color : Color = Color(0.8, 0.8, 0.8, 0.9)
var _editor_rect_border_size : int = 2
var _edited_resource_font_color : Color = Color(0, 0, 0, 1)
var _editor_additional_text : String = ""
var drag_type : int var drag_type : int
var drag_offset : Vector2 var drag_offset : Vector2
var drag_offset_far : Vector2 var drag_offset_far : Vector2
func _draw(): func _draw():
draw_rect(Rect2(Vector2(), get_size()), Color(1, 1, 1, 1)) draw_rect(Rect2(Vector2(), get_size()), _edited_resource_rect_color)
draw_rect(Rect2(Vector2(), get_size()), _edited_resource_rect_border_color, false, _editor_rect_border_size)
var font : Font = get_font("font")
var res_name : String = "NULL"
if edited_resource:
res_name = edited_resource.resource_name
draw_string(font, Vector2(_editor_rect_border_size, font.get_height()), res_name, _edited_resource_font_color)
draw_string(font, Vector2(_editor_rect_border_size, font.get_height() * 2), _editor_additional_text, _edited_resource_font_color, get_rect().size.x)
func refresh() -> void: func refresh() -> void:
if !edited_resource: if !edited_resource:
@ -33,8 +50,15 @@ func refresh() -> void:
func set_edited_resource(res : WorldGenBaseResource): func set_edited_resource(res : WorldGenBaseResource):
edited_resource = res edited_resource = res
if edited_resource:
_edited_resource_rect_border_color = edited_resource.get_editor_rect_border_color()
_edited_resource_rect_color = edited_resource.get_editor_rect_color()
_editor_rect_border_size = edited_resource.get_editor_rect_border_size()
_edited_resource_font_color = edited_resource.get_editor_font_color()
_editor_additional_text = edited_resource.get_editor_additional_text()
refresh() refresh()
#based on / ported from engine/scene/gui/dialogs.h and .cpp #based on / ported from engine/scene/gui/dialogs.h and .cpp
func _notification(p_what : int) -> void: func _notification(p_what : int) -> void:
if (p_what == NOTIFICATION_MOUSE_EXIT): if (p_what == NOTIFICATION_MOUSE_EXIT):