diff options
| author | dam <dam@gudinoff> | 2021-12-03 15:07:09 +0000 |
|---|---|---|
| committer | dam <dam@gudinoff> | 2021-12-03 15:07:09 +0000 |
| commit | 4faf8bb004dbb2161e736028469333b9b6c99775 (patch) | |
| tree | f5ff8521482a7671697d55f4c1b1a523446890da /date_picker | |
| parent | 7d515712404db480b6ba6eb45576ecc74988acd3 (diff) | |
| download | surgery-log-4faf8bb004dbb2161e736028469333b9b6c99775.tar.zst surgery-log-4faf8bb004dbb2161e736028469333b9b6c99775.zip | |
Remove datepicker hardcoded dimensions.
Diffstat (limited to 'date_picker')
| -rw-r--r-- | date_picker/date_picker.tscn | 167 | ||||
| -rw-r--r-- | date_picker/scroll_picker.gd | 28 |
2 files changed, 140 insertions, 55 deletions
diff --git a/date_picker/date_picker.tscn b/date_picker/date_picker.tscn index 88f98d8..84b2089 100644 --- a/date_picker/date_picker.tscn +++ b/date_picker/date_picker.tscn @@ -2,146 +2,225 @@ [ext_resource path="res://date_picker/scroll_picker.gd" type="Script" id=1] -[node name="date_picker" type="HBoxContainer"] +[node name="date_picker" type="Control"] anchor_right = 1.0 anchor_bottom = 1.0 mouse_filter = 2 -alignment = 1 __meta__ = { "_edit_use_anchors_": false } [node name="day_scroll" type="Control" parent="."] -margin_left = 5.0 -margin_right = 239.0 -margin_bottom = 1280.0 -rect_min_size = Vector2( 234, 0 ) +anchor_right = 0.333 +anchor_bottom = 1.0 script = ExtResource( 1 ) __meta__ = { "_edit_use_anchors_": false } -[node name="label" type="Label" parent="day_scroll"] +[node name="value_previous" type="Label" parent="day_scroll"] anchor_right = 1.0 -text = "day" +anchor_bottom = 0.333 +mouse_filter = 1 align = 1 +valign = 1 __meta__ = { "_edit_use_anchors_": false } -[node name="value_previous" type="Label" parent="day_scroll"] +[node name="ColorRect" type="ColorRect" parent="day_scroll/value_previous"] anchor_right = 1.0 -margin_bottom = 80.0 -mouse_filter = 1 -align = 1 +anchor_bottom = 1.0 +mouse_filter = 2 +color = Color( 0, 1, 1, 0.0980392 ) __meta__ = { "_edit_use_anchors_": false } [node name="value" type="Label" parent="day_scroll"] +anchor_top = 0.333 anchor_right = 1.0 -margin_top = 80.0 -margin_bottom = 160.0 +anchor_bottom = 0.666 mouse_filter = 1 align = 1 +valign = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect" type="ColorRect" parent="day_scroll/value"] +anchor_right = 1.0 +anchor_bottom = 1.0 +mouse_filter = 2 +color = Color( 1, 1, 1, 0.0980392 ) __meta__ = { "_edit_use_anchors_": false } [node name="value_next" type="Label" parent="day_scroll"] +anchor_top = 0.666 anchor_right = 1.0 -margin_top = 160.0 -margin_bottom = 240.0 +anchor_bottom = 1.0 mouse_filter = 1 align = 1 +valign = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect" type="ColorRect" parent="day_scroll/value_next"] +anchor_right = 1.0 +anchor_bottom = 1.0 +mouse_filter = 2 +color = Color( 1, 1, 0, 0.0980392 ) __meta__ = { "_edit_use_anchors_": false } [node name="month_scroll" type="Control" parent="."] -margin_left = 243.0 -margin_right = 477.0 -margin_bottom = 1280.0 -rect_min_size = Vector2( 234, 0 ) +anchor_left = 0.333 +anchor_right = 0.666 +anchor_bottom = 1.0 script = ExtResource( 1 ) -[node name="label" type="Label" parent="month_scroll"] +[node name="value_previous" type="Label" parent="month_scroll"] anchor_right = 1.0 -text = "month" +anchor_bottom = 0.333 +mouse_filter = 1 align = 1 +valign = 1 __meta__ = { "_edit_use_anchors_": false } -[node name="value_previous" type="Label" parent="month_scroll"] +[node name="ColorRect" type="ColorRect" parent="month_scroll/value_previous"] anchor_right = 1.0 -margin_bottom = 80.0 -mouse_filter = 1 -align = 1 +anchor_bottom = 1.0 +mouse_filter = 2 +color = Color( 0, 1, 1, 0.0980392 ) __meta__ = { "_edit_use_anchors_": false } [node name="value" type="Label" parent="month_scroll"] +anchor_top = 0.333 anchor_right = 1.0 -margin_top = 80.0 -margin_bottom = 160.0 +anchor_bottom = 0.666 mouse_filter = 1 align = 1 +valign = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect" type="ColorRect" parent="month_scroll/value"] +anchor_right = 1.0 +anchor_bottom = 1.0 +mouse_filter = 2 +color = Color( 1, 1, 1, 0.0980392 ) __meta__ = { "_edit_use_anchors_": false } [node name="value_next" type="Label" parent="month_scroll"] +anchor_top = 0.666 anchor_right = 1.0 -margin_top = 160.0 -margin_bottom = 240.0 +anchor_bottom = 1.0 mouse_filter = 1 align = 1 +valign = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect" type="ColorRect" parent="month_scroll/value_next"] +anchor_right = 1.0 +anchor_bottom = 1.0 +mouse_filter = 2 +color = Color( 1, 1, 0, 0.0980392 ) __meta__ = { "_edit_use_anchors_": false } [node name="year_scroll" type="Control" parent="."] -margin_left = 481.0 -margin_right = 715.0 -margin_bottom = 1280.0 -rect_min_size = Vector2( 234, 0 ) +anchor_left = 0.666 +anchor_right = 1.0 +anchor_bottom = 1.0 script = ExtResource( 1 ) -[node name="label" type="Label" parent="year_scroll"] +[node name="value_previous" type="Label" parent="year_scroll"] anchor_right = 1.0 -text = "year" +anchor_bottom = 0.333 +mouse_filter = 1 align = 1 +valign = 1 __meta__ = { "_edit_use_anchors_": false } -[node name="value_previous" type="Label" parent="year_scroll"] +[node name="ColorRect" type="ColorRect" parent="year_scroll/value_previous"] anchor_right = 1.0 -margin_bottom = 80.0 -mouse_filter = 1 -align = 1 +anchor_bottom = 1.0 +mouse_filter = 2 +color = Color( 0, 1, 1, 0.0980392 ) __meta__ = { "_edit_use_anchors_": false } [node name="value" type="Label" parent="year_scroll"] +anchor_top = 0.333 anchor_right = 1.0 -margin_top = 80.0 -margin_bottom = 160.0 +anchor_bottom = 0.666 mouse_filter = 1 align = 1 +valign = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect" type="ColorRect" parent="year_scroll/value"] +anchor_right = 1.0 +anchor_bottom = 1.0 +mouse_filter = 2 +color = Color( 1, 1, 1, 0.0980392 ) __meta__ = { "_edit_use_anchors_": false } [node name="value_next" type="Label" parent="year_scroll"] +anchor_top = 0.666 anchor_right = 1.0 -margin_top = 160.0 -margin_bottom = 240.0 +anchor_bottom = 1.0 mouse_filter = 1 align = 1 +valign = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect" type="ColorRect" parent="year_scroll/value_next"] +anchor_right = 1.0 +anchor_bottom = 1.0 +mouse_filter = 2 +color = Color( 1, 1, 0, 0.0980392 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="split_previous" type="ColorRect" parent="."] +anchor_top = 0.333 +anchor_right = 1.0 +anchor_bottom = 0.343 +color = Color( 1, 1, 1, 0.25 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="split_next" type="ColorRect" parent="."] +anchor_top = 0.666 +anchor_right = 1.0 +anchor_bottom = 0.676 +color = Color( 1, 1, 1, 0.25 ) __meta__ = { "_edit_use_anchors_": false } diff --git a/date_picker/scroll_picker.gd b/date_picker/scroll_picker.gd index ba70084..1d184b9 100644 --- a/date_picker/scroll_picker.gd +++ b/date_picker/scroll_picker.gd @@ -9,6 +9,10 @@ var pointer_id: int = -1 var start_pos: float = 0.0 var pos: float = 0.0 +var value_base_position: float +var value_next_base_position: float +var value_previous_base_position: float + func _ready(): pointer = { @@ -20,19 +24,23 @@ func _ready(): is_active = false, timestamp = 0 } + value_base_position = ($value as Label).rect_position.y + value_next_base_position = ($value_next as Label).rect_position.y + value_previous_base_position = ($value_previous as Label).rect_position.y func _process(delta: float): -# $label.text = "%s" % pointer.index - pointer.velocity *= clamp((1.0 - 5.5 * delta), 0.0, 1.0) # pow(1.0-0.995, delta) + + var max_value := 10 + var scroll_unit_height := ($value as Label).rect_size.y + + pointer.velocity *= clamp((1.0 - 5.5 * delta), 0.0, 1.0) if pointer.is_active: value = anchor + (pointer.current_position.y - pointer.initial_position.y) elif is_zero_approx(pointer.velocity.y) == false: value += pointer.velocity.y * delta if abs(pointer.velocity.y) < 50.0: - var max_value := 10 - var scroll_unit_height := 80 var normalized_value := -value / scroll_unit_height var normalized_int_value := round(normalized_value) as int var logic_value := fposmod(normalized_int_value, max_value) @@ -43,24 +51,22 @@ func _process(delta: float): # ($test as TextureRect).rect_global_position.y = value # $debug.text = "value: %s\nvelocity: %s\n%s" % [value, pointer.velocity, pointer.relative] var current_pos = value - var turn_over := 800 + var turn_over := scroll_unit_height * max_value if current_pos >= turn_over || current_pos < 0.0: value = fposmod(current_pos, turn_over) # elif current_pos < 0: # value = 800 - current_pos - var max_value := 10 - var scroll_unit_height := 40 var normalized_value := -value / scroll_unit_height var normalized_int_value := round(normalized_value) as int var logic_value := fposmod(normalized_int_value, max_value) var logic_next_value := fposmod(normalized_int_value + 1, max_value) var logic_previous_value := fposmod(normalized_int_value - 1, max_value) - var value_base_position := 140.0 # 180.0 - var value_next_base_position := 180.0 # 260.0 - var value_previous_base_position := 100.0 +# var value_base_position := ($value_previous as Label).rect_position.y # 140.0 # 180.0 +# var value_next_base_position := ($value_next as Label).rect_position.y #180.0 # 260.0 +# var value_previous_base_position := ($value as Label).rect_position.y #100.0 $value.text = "%d" % logic_value $value_next.text = "%d" % logic_next_value @@ -106,7 +112,7 @@ func _gui_input(event: InputEvent): # if pointer.is_active == false: # $output.text += "%10d: touch %d\n" % [abs(pointer.timestamp - time), touch.index] - if event is InputEventScreenDrag: # && pointer.index == event.index: + if event is InputEventScreenDrag && event.index == pointer.index: var drag := event as InputEventScreenDrag pointer.current_position = drag.position pointer.velocity = drag.speed |
