mirror of
https://github.com/TimeCrafters/timecrafters_configuration_tool_desktop.git
synced 2025-12-16 22:02:34 +00:00
Compare commits
7 Commits
v0.8.0
...
b17e24c630
| Author | SHA1 | Date | |
|---|---|---|---|
| b17e24c630 | |||
| f5f9870ae7 | |||
| cec3f90f3c | |||
| 93bfc80a97 | |||
| c37dc7112b | |||
| f60aadac72 | |||
| 628212b5e3 |
@@ -1,21 +1,18 @@
|
|||||||
GEM
|
GEM
|
||||||
remote: https://rubygems.org/
|
remote: https://rubygems.org/
|
||||||
specs:
|
specs:
|
||||||
cyberarm_engine (0.24.1)
|
cyberarm_engine (0.24.4)
|
||||||
excon (~> 0.88)
|
|
||||||
gosu (~> 1.1)
|
gosu (~> 1.1)
|
||||||
gosu_more_drawables (~> 0.3)
|
|
||||||
excon (0.109.0)
|
|
||||||
gosu (1.4.6)
|
gosu (1.4.6)
|
||||||
gosu_more_drawables (0.3.1)
|
|
||||||
ocran (1.3.15)
|
ocran (1.3.15)
|
||||||
|
|
||||||
PLATFORMS
|
PLATFORMS
|
||||||
x64-mingw-ucrt
|
x64-mingw-ucrt
|
||||||
|
x86_64-linux
|
||||||
|
|
||||||
DEPENDENCIES
|
DEPENDENCIES
|
||||||
cyberarm_engine
|
cyberarm_engine
|
||||||
ocran
|
ocran
|
||||||
|
|
||||||
BUNDLED WITH
|
BUNDLED WITH
|
||||||
2.5.3
|
2.5.14
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ module TAC
|
|||||||
@titlebar = flow(width: 1.0, height: 36) do
|
@titlebar = flow(width: 1.0, height: 36) do
|
||||||
background [TAC::Palette::TIMECRAFTERS_PRIMARY, TAC::Palette::TIMECRAFTERS_SECONDARY]
|
background [TAC::Palette::TIMECRAFTERS_PRIMARY, TAC::Palette::TIMECRAFTERS_SECONDARY]
|
||||||
|
|
||||||
label @title, text_size: THEME_SUBHEADING_TEXT_SIZE, font: TAC::THEME_BOLD_FONT, fill: true, text_align: :center, text_border: true, text_border_color: 0xaa_222222, text_border_size: 1
|
para @title, text_size: THEME_SUBHEADING_TEXT_SIZE, font: TAC::THEME_BOLD_FONT, fill: true, text_align: :center, text_border: true, text_border_color: 0xaa_222222, text_border_size: 1
|
||||||
|
|
||||||
button get_image("#{TAC::MEDIA_PATH}/icons/cross.png"), image_height: 1.0, **THEME_DANGER_BUTTON do
|
button get_image("#{TAC::MEDIA_PATH}/icons/cross.png"), image_height: 1.0, **THEME_DANGER_BUTTON do
|
||||||
close
|
close
|
||||||
|
|||||||
@@ -4,15 +4,15 @@ module TAC
|
|||||||
def build
|
def build
|
||||||
background Gosu::Color::GRAY
|
background Gosu::Color::GRAY
|
||||||
|
|
||||||
label "Name", width: 1.0, text_align: :center
|
para "Name", width: 1.0, text_align: :center
|
||||||
@name_error = label "Error", color: TAC::Palette::TACNET_CONNECTION_ERROR
|
@name_error = para "Error", color: TAC::Palette::TACNET_CONNECTION_ERROR
|
||||||
@name_error.hide
|
@name_error.hide
|
||||||
@name = edit_line @options[:action] ? @options[:action].name : "", filter: method(:name_filter), width: 1.0, autofocus: true, focus: true
|
@name = edit_line @options[:action] ? @options[:action].name : "", filter: method(:name_filter), width: 1.0, autofocus: true, focus: true
|
||||||
@name.subscribe(:changed) do |sender, value|
|
@name.subscribe(:changed) do |sender, value|
|
||||||
valid?
|
valid?
|
||||||
end
|
end
|
||||||
|
|
||||||
label "Comment", width: 1.0, text_align: :center
|
para "Comment", width: 1.0, text_align: :center
|
||||||
@comment = edit_line @options[:action] ? @options[:action].comment : "", width: 1.0
|
@comment = edit_line @options[:action] ? @options[:action].comment : "", width: 1.0
|
||||||
|
|
||||||
flow width: 1.0, margin_top: THEME_DIALOG_BUTTON_PADDING do
|
flow width: 1.0, margin_top: THEME_DIALOG_BUTTON_PADDING do
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ module TAC
|
|||||||
class AlertDialog < Dialog
|
class AlertDialog < Dialog
|
||||||
def build
|
def build
|
||||||
background Gosu::Color::GRAY
|
background Gosu::Color::GRAY
|
||||||
label @options[:message]
|
para @options[:message]
|
||||||
|
|
||||||
button "Close", width: 1.0, margin_top: THEME_DIALOG_BUTTON_PADDING do
|
button "Close", width: 1.0, margin_top: THEME_DIALOG_BUTTON_PADDING do
|
||||||
try_commit
|
try_commit
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ module TAC
|
|||||||
@titlebar.style.default[:background] = [ color, darken(color, 50) ]
|
@titlebar.style.default[:background] = [ color, darken(color, 50) ]
|
||||||
|
|
||||||
background Gosu::Color::GRAY
|
background Gosu::Color::GRAY
|
||||||
label @options[:message]
|
para @options[:message]
|
||||||
|
|
||||||
flow width: 1.0, margin_top: THEME_DIALOG_BUTTON_PADDING do
|
flow width: 1.0, margin_top: THEME_DIALOG_BUTTON_PADDING do
|
||||||
button "Cancel", width: 0.5 do
|
button "Cancel", width: 0.5 do
|
||||||
|
|||||||
@@ -5,8 +5,8 @@ module TAC
|
|||||||
|
|
||||||
def build
|
def build
|
||||||
background Gosu::Color::GRAY
|
background Gosu::Color::GRAY
|
||||||
label "Name", width: 1.0, text_align: :center
|
para "Name", width: 1.0, text_align: :center
|
||||||
@name_error = label "", color: TAC::Palette::TACNET_CONNECTION_ERROR
|
@name_error = para "", color: TAC::Palette::TACNET_CONNECTION_ERROR
|
||||||
@name_error.hide
|
@name_error.hide
|
||||||
@name = edit_line @options[:renaming] ? @options[:renaming].name : "", filter: method(:name_filter), width: 1.0, autofocus: true, focus: true
|
@name = edit_line @options[:renaming] ? @options[:renaming].name : "", filter: method(:name_filter), width: 1.0, autofocus: true, focus: true
|
||||||
|
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ module TAC
|
|||||||
@titlebar.style.default[:background] = [ Palette::TACNET_PRIMARY, Palette::TACNET_SECONDARY ]
|
@titlebar.style.default[:background] = [ Palette::TACNET_PRIMARY, Palette::TACNET_SECONDARY ]
|
||||||
|
|
||||||
background Gosu::Color::GRAY
|
background Gosu::Color::GRAY
|
||||||
label @options[:message], width: 1.0
|
para @options[:message], width: 1.0
|
||||||
|
|
||||||
@sound = Gosu::Sample.new("#{TAC::MEDIA_PATH}/error_alarm.ogg").play(1, 1, true)
|
@sound = Gosu::Sample.new("#{TAC::MEDIA_PATH}/error_alarm.ogg").play(1, 1, true)
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ module TAC
|
|||||||
class TACNETStatusDialog < Dialog
|
class TACNETStatusDialog < Dialog
|
||||||
def build
|
def build
|
||||||
background Gosu::Color::GRAY
|
background Gosu::Color::GRAY
|
||||||
@message_label = label CyberarmEngine::Window.instance.backend.tacnet.full_status
|
@message_label = para CyberarmEngine::Window.instance.backend.tacnet.full_status
|
||||||
|
|
||||||
button "Close", width: 1.0, margin_top: THEME_DIALOG_BUTTON_PADDING do
|
button "Close", width: 1.0, margin_top: THEME_DIALOG_BUTTON_PADDING do
|
||||||
try_commit
|
try_commit
|
||||||
|
|||||||
@@ -6,16 +6,16 @@ module TAC
|
|||||||
|
|
||||||
@type = @options[:variable].type if @options[:variable]
|
@type = @options[:variable].type if @options[:variable]
|
||||||
|
|
||||||
label "Name", width: 1.0, text_align: :center
|
para "Name", width: 1.0, text_align: :center
|
||||||
@name_error = label "Error", color: TAC::Palette::TACNET_CONNECTION_ERROR
|
@name_error = para "Error", color: TAC::Palette::TACNET_CONNECTION_ERROR
|
||||||
@name_error.hide
|
@name_error.hide
|
||||||
@name = edit_line @options[:variable] ? @options[:variable].name : "", filter: method(:name_filter), width: 1.0, autofocus: true, focus: true
|
@name = edit_line @options[:variable] ? @options[:variable].name : "", filter: method(:name_filter), width: 1.0, autofocus: true, focus: true
|
||||||
@name.subscribe(:changed) do |sender, value|
|
@name.subscribe(:changed) do |sender, value|
|
||||||
valid?
|
valid?
|
||||||
end
|
end
|
||||||
|
|
||||||
label "Type", width: 1.0, text_align: :center
|
para "Type", width: 1.0, text_align: :center
|
||||||
@type_error = label "Error", color: TAC::Palette::TACNET_CONNECTION_ERROR
|
@type_error = para "Error", color: TAC::Palette::TACNET_CONNECTION_ERROR
|
||||||
@type_error.hide
|
@type_error.hide
|
||||||
|
|
||||||
@var_type = list_box items: [:float, :double, :integer, :long, :string, :boolean], choose: @type ? @type : :double, width: 1.0 do |item|
|
@var_type = list_box items: [:float, :double, :integer, :long, :string, :boolean], choose: @type ? @type : :double, width: 1.0 do |item|
|
||||||
@@ -35,8 +35,8 @@ module TAC
|
|||||||
@type ||= @var_type.value.to_sym
|
@type ||= @var_type.value.to_sym
|
||||||
|
|
||||||
@value_container = stack width: 1.0 do
|
@value_container = stack width: 1.0 do
|
||||||
label "Value", width: 1.0, text_align: :center
|
para "Value", width: 1.0, text_align: :center
|
||||||
@value_error = label "Error", color: TAC::Palette::TACNET_CONNECTION_ERROR
|
@value_error = para "Error", color: TAC::Palette::TACNET_CONNECTION_ERROR
|
||||||
@value_error.hide
|
@value_error.hide
|
||||||
@value = edit_line @options[:variable] ? @options[:variable].value : "", width: 1.0
|
@value = edit_line @options[:variable] ? @options[:variable].value : "", width: 1.0
|
||||||
@value_boolean = check_box "Boolean", checked: @options[:variable] ? @options[:variable].value == "true" : false
|
@value_boolean = check_box "Boolean", checked: @options[:variable] ? @options[:variable].value == "true" : false
|
||||||
|
|||||||
@@ -42,7 +42,7 @@ module TAC
|
|||||||
end
|
end
|
||||||
|
|
||||||
### --- ###
|
### --- ###
|
||||||
# OVERRIDE: offical CenterStage game clock no longer has colors
|
# OVERRIDE: official CenterStage game clock no longer has colors
|
||||||
### --- ###
|
### --- ###
|
||||||
|
|
||||||
out = Gosu::Color::WHITE
|
out = Gosu::Color::WHITE
|
||||||
|
|||||||
@@ -95,13 +95,13 @@ module TAC
|
|||||||
background @menu_background
|
background @menu_background
|
||||||
|
|
||||||
flow(width: 1.0) do
|
flow(width: 1.0) do
|
||||||
label "♫ Now playing:"
|
para "♫ Now playing:"
|
||||||
@current_song_label = label "♫ ♫ ♫"
|
@current_song_label = para "♫ ♫ ♫"
|
||||||
end
|
end
|
||||||
|
|
||||||
flow(width: 1.0) do
|
flow(width: 1.0) do
|
||||||
label "Volume:"
|
para "Volume:"
|
||||||
@current_volume_label = label "100%"
|
@current_volume_label = para "100%"
|
||||||
end
|
end
|
||||||
|
|
||||||
flow(width: 1.0) do
|
flow(width: 1.0) do
|
||||||
|
|||||||
@@ -27,8 +27,8 @@ module TAC
|
|||||||
|
|
||||||
status_bar.clear do
|
status_bar.clear do
|
||||||
flow(width: 1.0, max_width: 720, h_align: :center) do
|
flow(width: 1.0, max_width: 720, h_align: :center) do
|
||||||
label "Current Configuration: "
|
para "Current Configuration: "
|
||||||
@config_label = label window.backend.settings.config
|
@config_label = para window.backend.settings.config
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -30,13 +30,13 @@ module TAC
|
|||||||
|
|
||||||
status_bar.clear do
|
status_bar.clear do
|
||||||
flow(width: 0.3333) do
|
flow(width: 0.3333) do
|
||||||
label "Active group:", margin_right: 20
|
para "Active group:", margin_right: 20
|
||||||
@active_group_label = label ""
|
@active_group_label = para ""
|
||||||
end
|
end
|
||||||
|
|
||||||
flow(width: 0.3333) do
|
flow(width: 0.3333) do
|
||||||
label "Active action:", margin_right: 20
|
para "Active action:", margin_right: 20
|
||||||
@active_action_label = label ""
|
@active_action_label = para ""
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -44,7 +44,7 @@ module TAC
|
|||||||
flow(width: 1.0, height: 1.0) do
|
flow(width: 1.0, height: 1.0) do
|
||||||
stack fill: true, height: 1.0, padding_left: 2, padding_right: 2, border_thickness_right: 1, border_color: Gosu::Color::BLACK do
|
stack fill: true, height: 1.0, padding_left: 2, padding_right: 2, border_thickness_right: 1, border_color: Gosu::Color::BLACK do
|
||||||
@groups_menu = flow(width: 1.0, height: 36) do
|
@groups_menu = flow(width: 1.0, height: 36) do
|
||||||
label "Groups", text_size: THEME_SUBHEADING_TEXT_SIZE, fill: true, text_align: :center
|
para "Groups", text_size: THEME_SUBHEADING_TEXT_SIZE, fill: true, text_align: :center
|
||||||
|
|
||||||
button get_image("#{TAC::MEDIA_PATH}/icons/plus.png"), image_width: THEME_ICON_SIZE, tip: "Add group" do
|
button get_image("#{TAC::MEDIA_PATH}/icons/plus.png"), image_width: THEME_ICON_SIZE, tip: "Add group" do
|
||||||
push_state(TAC::Dialog::NamePromptDialog, title: "Create Group", list: window.backend.config.groups, callback_method: method(:create_group))
|
push_state(TAC::Dialog::NamePromptDialog, title: "Create Group", list: window.backend.config.groups, callback_method: method(:create_group))
|
||||||
@@ -117,7 +117,7 @@ module TAC
|
|||||||
|
|
||||||
stack fill: true, height: 1.0, padding_left: 2, padding_right: 2, border_thickness_right: 1, border_color: Gosu::Color::BLACK do
|
stack fill: true, height: 1.0, padding_left: 2, padding_right: 2, border_thickness_right: 1, border_color: Gosu::Color::BLACK do
|
||||||
@actions_menu = flow(width: 1.0, height: 36) do
|
@actions_menu = flow(width: 1.0, height: 36) do
|
||||||
label "Actions", text_size: THEME_SUBHEADING_TEXT_SIZE, fill: true, text_align: :center
|
para "Actions", text_size: THEME_SUBHEADING_TEXT_SIZE, fill: true, text_align: :center
|
||||||
|
|
||||||
# TODO: Implement this
|
# TODO: Implement this
|
||||||
# button get_image("#{TAC::MEDIA_PATH}/icons/barsHorizontal.png"), image_width: THEME_ICON_SIZE, tip: "Auto renumber engine actions", margin_right: 16, enabled: false do
|
# button get_image("#{TAC::MEDIA_PATH}/icons/barsHorizontal.png"), image_width: THEME_ICON_SIZE, tip: "Auto renumber engine actions", margin_right: 16, enabled: false do
|
||||||
@@ -221,7 +221,7 @@ module TAC
|
|||||||
|
|
||||||
stack fill: true, height: 1.0, padding_left: 2, padding_right: 2 do
|
stack fill: true, height: 1.0, padding_left: 2, padding_right: 2 do
|
||||||
@variables_menu = flow(width: 1.0, height: 36) do
|
@variables_menu = flow(width: 1.0, height: 36) do
|
||||||
label "Variables", text_size: THEME_SUBHEADING_TEXT_SIZE, fill: true, text_align: :center
|
para "Variables", text_size: THEME_SUBHEADING_TEXT_SIZE, fill: true, text_align: :center
|
||||||
button get_image("#{TAC::MEDIA_PATH}/icons/plus.png"), image_width: THEME_ICON_SIZE, tip: "Add variable" do
|
button get_image("#{TAC::MEDIA_PATH}/icons/plus.png"), image_width: THEME_ICON_SIZE, tip: "Add variable" do
|
||||||
if @active_action
|
if @active_action
|
||||||
push_state(TAC::Dialog::VariableDialog, title: "Create Variable", list: @active_action.variables, callback_method: method(:create_variable))
|
push_state(TAC::Dialog::VariableDialog, title: "Create Variable", list: @active_action.variables, callback_method: method(:create_variable))
|
||||||
@@ -325,7 +325,7 @@ module TAC
|
|||||||
window.backend.config_changed!
|
window.backend.config_changed!
|
||||||
|
|
||||||
group_container = find_element_by_tag(@groups_list, old_name)
|
group_container = find_element_by_tag(@groups_list, old_name)
|
||||||
label = find_element_by_tag(group_container, "label")
|
para = find_element_by_tag(group_container, "label")
|
||||||
|
|
||||||
label.value = name
|
label.value = name
|
||||||
|
|
||||||
@@ -382,7 +382,7 @@ module TAC
|
|||||||
window.backend.config_changed!
|
window.backend.config_changed!
|
||||||
|
|
||||||
action_container = find_element_by_tag(@actions_list, old_name)
|
action_container = find_element_by_tag(@actions_list, old_name)
|
||||||
label = find_element_by_tag(action_container, "label")
|
para = find_element_by_tag(action_container, "label")
|
||||||
comment_container = find_element_by_tag(action_container, "comment_container")
|
comment_container = find_element_by_tag(action_container, "comment_container")
|
||||||
comment_label = find_element_by_tag(action_container, "comment")
|
comment_label = find_element_by_tag(action_container, "comment")
|
||||||
|
|
||||||
@@ -454,11 +454,11 @@ module TAC
|
|||||||
window.backend.config_changed!
|
window.backend.config_changed!
|
||||||
|
|
||||||
variable_container = find_element_by_tag(@variables_list, old_name)
|
variable_container = find_element_by_tag(@variables_list, old_name)
|
||||||
label = find_element_by_tag(variable_container, "label")
|
para = find_element_by_tag(variable_container, "label")
|
||||||
type = find_element_by_tag(variable_container, "type")
|
type = find_element_by_tag(variable_container, "type")
|
||||||
value = find_element_by_tag(variable_container, "value")
|
value = find_element_by_tag(variable_container, "value")
|
||||||
|
|
||||||
label.value = name
|
para.value = name
|
||||||
type.value = "Type: #{variable.type}"
|
type.value = "Type: #{variable.type}"
|
||||||
value.value = "Value: #{variable.value}"
|
value.value = "Value: #{variable.value}"
|
||||||
|
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ module TAC
|
|||||||
refresh_panel
|
refresh_panel
|
||||||
end
|
end
|
||||||
|
|
||||||
list_box items: ["CENTERSTAGE", "Power Play", "Freight Frenzy", "Ultimate Goal", "Skystone"], width: 200, height: 1.0 do |item|
|
list_box items: ["Into the Deep", "CENTERSTAGE", "Power Play", "Freight Frenzy", "Ultimate Goal", "Skystone"], width: 200, height: 1.0 do |item|
|
||||||
season = item.downcase.gsub(" ", "_").to_sym
|
season = item.downcase.gsub(" ", "_").to_sym
|
||||||
@field = TAC::Simulator::Field.new(container: @field_container, season: season, simulation: nil)
|
@field = TAC::Simulator::Field.new(container: @field_container, season: season, simulation: nil)
|
||||||
end
|
end
|
||||||
@@ -63,12 +63,12 @@ module TAC
|
|||||||
background 0xff_111111
|
background 0xff_111111
|
||||||
end
|
end
|
||||||
|
|
||||||
@points_container = stack width: 0.5, height: 1.0 do
|
@points_container = stack width: 0.5, height: 1.0, scroll: true do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@field = TAC::Simulator::Field.new(container: @field_container, season: :centerstage, simulation: nil)
|
@field = TAC::Simulator::Field.new(container: @field_container, season: :into_the_deep, simulation: nil)
|
||||||
@nodes ||= []
|
@nodes ||= []
|
||||||
@unit = :inches
|
@unit = :inches
|
||||||
@total_distance = 0
|
@total_distance = 0
|
||||||
@@ -97,7 +97,8 @@ module TAC
|
|||||||
x = (window.mouse_x - @field_container.x) / @field.scale - 72
|
x = (window.mouse_x - @field_container.x) / @field.scale - 72
|
||||||
y = (window.mouse_y - @field_container.y) / @field.scale - 72
|
y = (window.mouse_y - @field_container.y) / @field.scale - 72
|
||||||
|
|
||||||
@font.text = "X: #{inches_to_unit(x).round(2)} Y: #{inches_to_unit(y).round(2)} (#{@unit.to_s})"
|
|
||||||
|
@font.text = "X: #{inches_to_unit(-y).round(2)} Y: #{inches_to_unit(-x).round(2)} (#{@unit.to_s})"
|
||||||
@font.x = window.mouse_x + 6
|
@font.x = window.mouse_x + 6
|
||||||
@font.y = window.mouse_y - (@font.height / 2.0 + 24)
|
@font.y = window.mouse_y - (@font.height / 2.0 + 24)
|
||||||
@font.z = 100_001
|
@font.z = 100_001
|
||||||
@@ -133,16 +134,20 @@ module TAC
|
|||||||
x = (window.mouse_x - @field_container.x) / @field.scale
|
x = (window.mouse_x - @field_container.x) / @field.scale
|
||||||
y = (window.mouse_y - @field_container.y) / @field.scale
|
y = (window.mouse_y - @field_container.y) / @field.scale
|
||||||
|
|
||||||
|
field_x = -((window.mouse_y - @field_container.y) / @field.scale - 72)
|
||||||
|
field_y = -((window.mouse_x - @field_container.x) / @field.scale - 72)
|
||||||
|
|
||||||
case id
|
case id
|
||||||
when Gosu::MS_LEFT # Add Node
|
when Gosu::MS_LEFT # Add Node
|
||||||
@nodes << CyberarmEngine::Vector.new(x, y, 0)
|
@nodes << [CyberarmEngine::Vector.new(x, y, 0), CyberarmEngine::Vector.new(field_x, field_y, 0)]
|
||||||
|
|
||||||
measure_path
|
measure_path
|
||||||
|
|
||||||
refresh_panel
|
refresh_panel
|
||||||
|
|
||||||
when Gosu::MS_RIGHT # Delete Node
|
when Gosu::MS_RIGHT # Delete Node
|
||||||
result = @nodes.find do |node|
|
result = @nodes.find do |node_pair|
|
||||||
|
node = node_pair.first
|
||||||
Gosu.distance(node.x, node.y, x, y) <= @node_radius * 0.25
|
Gosu.distance(node.x, node.y, x, y) <= @node_radius * 0.25
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -159,9 +164,10 @@ module TAC
|
|||||||
x = (window.mouse_x - @field_container.x) / @field.scale
|
x = (window.mouse_x - @field_container.x) / @field.scale
|
||||||
y = (window.mouse_y - @field_container.y) / @field.scale
|
y = (window.mouse_y - @field_container.y) / @field.scale
|
||||||
|
|
||||||
last_node = @nodes.first
|
last_node = @nodes.first&.first
|
||||||
|
|
||||||
@nodes.each_with_index do |current_node, i|
|
@nodes.each_with_index do |current_node_pair, i|
|
||||||
|
current_node = current_node_pair.first
|
||||||
mouse_near = Gosu.distance(current_node.x, current_node.y, x, y) <= @node_radius * 0.25
|
mouse_near = Gosu.distance(current_node.x, current_node.y, x, y) <= @node_radius * 0.25
|
||||||
|
|
||||||
Gosu.draw_circle(
|
Gosu.draw_circle(
|
||||||
@@ -199,10 +205,12 @@ module TAC
|
|||||||
def measure_path
|
def measure_path
|
||||||
@total_distance = 0
|
@total_distance = 0
|
||||||
|
|
||||||
v1 = @nodes.first
|
v1 = @nodes.first&.first
|
||||||
@nodes.each_with_index do |v2, i|
|
@nodes.each_with_index do |pair, i|
|
||||||
next if i.zero?
|
next if i.zero?
|
||||||
|
|
||||||
|
v2 = pair.first
|
||||||
|
|
||||||
@total_distance += Gosu.distance(
|
@total_distance += Gosu.distance(
|
||||||
v1.x + @field_container.x,
|
v1.x + @field_container.x,
|
||||||
v1.y + @field_container.y,
|
v1.y + @field_container.y,
|
||||||
@@ -224,24 +232,9 @@ module TAC
|
|||||||
status_bar.recalculate
|
status_bar.recalculate
|
||||||
|
|
||||||
# @points_container.clear do
|
# @points_container.clear do
|
||||||
# v1 = @nodes.first
|
# @nodes.each_with_index do |pair, i|
|
||||||
# break unless v1
|
# v = pair.last
|
||||||
|
# para format("X: %.3f Y: %.3f", inches_to_unit(v.x), inches_to_unit(v.y))
|
||||||
# para "Vector #{inches_to_unit(v1.x).round}:#{inches_to_unit(v1.y).round} - 0 #{@unit.to_s.capitalize}"
|
|
||||||
|
|
||||||
# @nodes.each_with_index do |v2, i|
|
|
||||||
# next if i.zero?
|
|
||||||
|
|
||||||
# distance = Gosu.distance(
|
|
||||||
# v1.x + @field_container.x,
|
|
||||||
# v1.y + @field_container.y,
|
|
||||||
# v2.x + @field_container.x,
|
|
||||||
# v2.y + @field_container.y
|
|
||||||
# )
|
|
||||||
|
|
||||||
# para "Vector #{inches_to_unit(v1.x).round}:#{inches_to_unit(v1.y).round} - #{inches_to_unit(distance).round(2)} #{@unit.to_s.capitalize}"
|
|
||||||
|
|
||||||
# v1 = v2
|
|
||||||
# end
|
# end
|
||||||
# end
|
# end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -6,33 +6,33 @@ module TAC
|
|||||||
|
|
||||||
body.clear do
|
body.clear do
|
||||||
stack(width: 1.0, height: 1.0) do
|
stack(width: 1.0, height: 1.0) do
|
||||||
label TAC::NAME, width: 1.0, text_size: 48, text_align: :center
|
para TAC::NAME, width: 1.0, text_size: 48, text_align: :center
|
||||||
|
|
||||||
stack(width: 1.0, height: 8) do
|
stack(width: 1.0, height: 8) do
|
||||||
background 0xff_006000
|
background 0xff_006000
|
||||||
end
|
end
|
||||||
|
|
||||||
if window.backend.settings.config.empty?
|
if window.backend.settings.config.empty? || window.backend.config.nil?
|
||||||
label "TODO: Introduction"
|
para "TODO: Introduction"
|
||||||
label "Get Started", text_size: 28
|
para "Get Started", text_size: 28
|
||||||
button "1. Create a configuration" do
|
button "1. Create a configuration" do
|
||||||
page(TAC::Pages::Configurations)
|
page(TAC::Pages::Configurations)
|
||||||
end
|
end
|
||||||
label "2. Add a group"
|
para "2. Add a group"
|
||||||
label "3. Add an action"
|
para "3. Add an action"
|
||||||
label "4. Add a variable"
|
para "4. Add a variable"
|
||||||
label "5. Profit?"
|
para "5. Profit?"
|
||||||
else
|
else
|
||||||
label "Display config stats or something?"
|
para "Display config stats or something?"
|
||||||
|
|
||||||
config = window.backend.config
|
config = window.backend.config
|
||||||
groups = config.groups
|
groups = config.groups
|
||||||
actions = config.groups.map { |g| g.actions }.flatten
|
actions = config.groups.map { |g| g.actions }.flatten
|
||||||
variables = actions.map { |a| a.variables }.flatten
|
variables = actions.map { |a| a.variables }.flatten
|
||||||
|
|
||||||
label "Total groups: #{groups.size}"
|
para "Total groups: #{groups.size}"
|
||||||
label "Total actions: #{actions.size}"
|
para "Total actions: #{actions.size}"
|
||||||
label "Total variables: #{variables.size}"
|
para "Total variables: #{variables.size}"
|
||||||
end
|
end
|
||||||
|
|
||||||
stack(width: 1.0, fill: true, scroll: true, margin_top: 32) do
|
stack(width: 1.0, fill: true, scroll: true, margin_top: 32) do
|
||||||
|
|||||||
@@ -201,7 +201,7 @@ module TAC
|
|||||||
window.backend.config_changed!
|
window.backend.config_changed!
|
||||||
|
|
||||||
group_container = find_element_by_tag(@group_presets, old_name)
|
group_container = find_element_by_tag(@group_presets, old_name)
|
||||||
label = find_element_by_tag(group_container, "label")
|
para = find_element_by_tag(group_container, "label")
|
||||||
|
|
||||||
label.value = name
|
label.value = name
|
||||||
|
|
||||||
@@ -233,7 +233,7 @@ module TAC
|
|||||||
window.backend.config_changed!
|
window.backend.config_changed!
|
||||||
|
|
||||||
action_container = find_element_by_tag(@action_presets, old_name)
|
action_container = find_element_by_tag(@action_presets, old_name)
|
||||||
label = find_element_by_tag(action_container, "label")
|
para = find_element_by_tag(action_container, "label")
|
||||||
comment_container = find_element_by_tag(action_container, "comment_container")
|
comment_container = find_element_by_tag(action_container, "comment_container")
|
||||||
comment_label = find_element_by_tag(action_container, "comment")
|
comment_label = find_element_by_tag(action_container, "comment")
|
||||||
|
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ module TAC
|
|||||||
end
|
end
|
||||||
|
|
||||||
status_bar.clear do
|
status_bar.clear do
|
||||||
@simulation_status = label ""
|
@simulation_status = para ""
|
||||||
end
|
end
|
||||||
|
|
||||||
body.clear do
|
body.clear do
|
||||||
|
|||||||
@@ -6,9 +6,9 @@ module TAC
|
|||||||
|
|
||||||
menu_bar.clear do
|
menu_bar.clear do
|
||||||
@connect_menu = flow(width: 1.0, height: 1.0) do
|
@connect_menu = flow(width: 1.0, height: 1.0) do
|
||||||
label "Hostname", text_size: 28
|
para "Hostname", text_size: 28
|
||||||
hostname = edit_line window.backend.settings.hostname, width: 0.33, height: 1.0, text_size: 28
|
hostname = edit_line window.backend.settings.hostname, width: 0.33, height: 1.0, text_size: 28
|
||||||
label "Port", text_size: 28
|
para "Port", text_size: 28
|
||||||
port = edit_line window.backend.settings.port, width: 0.33, height: 1.0, text_size: 28
|
port = edit_line window.backend.settings.port, width: 0.33, height: 1.0, text_size: 28
|
||||||
button "Connect", height: 1.0, text_size: 28 do
|
button "Connect", height: 1.0, text_size: 28 do
|
||||||
if hostname.value != window.backend.settings.hostname || port.value.to_i != window.backend.settings.port
|
if hostname.value != window.backend.settings.hostname || port.value.to_i != window.backend.settings.port
|
||||||
@@ -31,11 +31,11 @@ module TAC
|
|||||||
|
|
||||||
status_bar.clear do
|
status_bar.clear do
|
||||||
@tacnet_icon = image "#{TAC::MEDIA_PATH}/icons/signal3.png", height: 26
|
@tacnet_icon = image "#{TAC::MEDIA_PATH}/icons/signal3.png", height: 26
|
||||||
@status_label = label "TACNET: Not Connected", text_size: 26
|
@status_label = para "TACNET: Not Connected", text_size: 26
|
||||||
end
|
end
|
||||||
|
|
||||||
body.clear do
|
body.clear do
|
||||||
@full_status_label = label ""
|
@full_status_label = para ""
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -336,9 +336,7 @@ module TAC
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
###########################
|
|
||||||
### --- CENTERSTAGE --- ###
|
|
||||||
###########################
|
|
||||||
def draw_field_centerstage
|
def draw_field_centerstage
|
||||||
# Corner TAPE
|
# Corner TAPE
|
||||||
2.times do |i|
|
2.times do |i|
|
||||||
@@ -441,6 +439,140 @@ module TAC
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
#############################
|
||||||
|
### --- Into the Deep --- ###
|
||||||
|
#############################
|
||||||
|
def draw_field_into_the_deep
|
||||||
|
# Observation and net zones
|
||||||
|
2.times do |i|
|
||||||
|
Gosu.rotate(i * 180.0, 72, 72) do
|
||||||
|
Gosu.draw_quad(
|
||||||
|
24 - 2, 0, i.odd? ? @red : @blue,
|
||||||
|
24, 0, i.odd? ? @red : @blue,
|
||||||
|
0, 24 - 2, i.odd? ? @red : @blue,
|
||||||
|
0, 24, i.odd? ? @red : @blue,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
|
||||||
|
Gosu.draw_rect(
|
||||||
|
12, 144 - 24,
|
||||||
|
2, 24,
|
||||||
|
i.odd? ? @red : @blue,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
|
||||||
|
Gosu.draw_quad(
|
||||||
|
12, 144 - 24, i.odd? ? @red : @blue,
|
||||||
|
14, 144 - 24, i.odd? ? @red : @blue,
|
||||||
|
0, 144 - 36, i.odd? ? @red : @blue,
|
||||||
|
0, 144 - 38, i.odd? ? @red : @blue,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
faint_white = Gosu::Color.rgb(240, 240, 240)
|
||||||
|
|
||||||
|
# spike marks, white
|
||||||
|
3.times do |i|
|
||||||
|
Gosu.draw_rect(
|
||||||
|
48 - 3.5, 22 - i * 10,
|
||||||
|
3.5, 2,
|
||||||
|
faint_white,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
end
|
||||||
|
#spike marks, red
|
||||||
|
3.times do |i|
|
||||||
|
Gosu.draw_rect(
|
||||||
|
(144 - 48), 22 - i * 10,
|
||||||
|
3.5, 2,
|
||||||
|
@red,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
end
|
||||||
|
# spike marks, blue
|
||||||
|
3.times do |i|
|
||||||
|
Gosu.draw_rect(
|
||||||
|
48 - 3.5, 144 - 24 + i * 10,
|
||||||
|
3.5, 2,
|
||||||
|
@blue,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
end
|
||||||
|
# spike marks, yellow
|
||||||
|
3.times do |i|
|
||||||
|
Gosu.draw_rect(
|
||||||
|
(144 - 48), 144 - 24 + i * 10,
|
||||||
|
3.5, 2,
|
||||||
|
faint_white,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
# Accent Zone Triangle TAPE
|
||||||
|
2.times do |i|
|
||||||
|
Gosu.rotate(i * 180.0, 72, 72) do
|
||||||
|
Gosu.draw_quad(
|
||||||
|
48, 48, faint_white,
|
||||||
|
72, 48 - 10, faint_white,
|
||||||
|
72, 49 - 10, faint_white,
|
||||||
|
50, 48, faint_white,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
|
||||||
|
Gosu.draw_quad(
|
||||||
|
96, 48, faint_white,
|
||||||
|
72, 48 - 10, faint_white,
|
||||||
|
72, 49 - 10, faint_white,
|
||||||
|
94, 48, faint_white,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# submersible
|
||||||
|
bar_gray = 0xff_656565 #Gosu::Color.rgb(50, 50, 50)
|
||||||
|
|
||||||
|
2.times do |i|
|
||||||
|
# left and right edges of submersible
|
||||||
|
Gosu.draw_rect(
|
||||||
|
72 - 24 + i * 46, 72 - 24,
|
||||||
|
2, 48,
|
||||||
|
bar_gray,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
|
||||||
|
# top and bottom edges of submersible
|
||||||
|
Gosu.draw_rect(
|
||||||
|
72 - 24, 72 - 15 + i * 28,
|
||||||
|
48, 2,
|
||||||
|
bar_gray,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
|
||||||
|
# alliance rungs of submersible
|
||||||
|
Gosu.draw_rect(
|
||||||
|
72 - 24 + i * 46, 72 - 13,
|
||||||
|
2, 26,
|
||||||
|
i.even? ? @blue : @red,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
# alliance bar bars
|
||||||
|
2.times do |i|
|
||||||
|
3.times do |x|
|
||||||
|
Gosu.draw_rect(
|
||||||
|
72 - 21.5 + x * 21, 72 - 15 + i * 28,
|
||||||
|
1, 2,
|
||||||
|
i.even? ? @blue : @red,
|
||||||
|
@z
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def draw_tile_box(color)
|
def draw_tile_box(color)
|
||||||
Gosu.draw_rect(0, 0, 24, 2, color, @z)
|
Gosu.draw_rect(0, 0, 24, 2, color, @z)
|
||||||
Gosu.draw_rect(22, 2, 2, 22, color, @z)
|
Gosu.draw_rect(22, 2, 2, 22, color, @z)
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ module TAC
|
|||||||
@field_container = field_container
|
@field_container = field_container
|
||||||
|
|
||||||
@robots = []
|
@robots = []
|
||||||
@field = Field.new(simulation: self, season: :centerstage, container: @field_container)
|
@field = Field.new(simulation: self, season: :into_the_deep, container: @field_container)
|
||||||
@show_paths = false
|
@show_paths = false
|
||||||
|
|
||||||
@last_milliseconds = Gosu.milliseconds
|
@last_milliseconds = Gosu.milliseconds
|
||||||
|
|||||||
@@ -36,7 +36,7 @@ class Editor < CyberarmEngine::GuiState
|
|||||||
@header_bar = flow(width: 1.0, height: 36) do
|
@header_bar = flow(width: 1.0, height: 36) do
|
||||||
background 0xff_006000
|
background 0xff_006000
|
||||||
|
|
||||||
@header_bar_label = label TAC::NAME, fill: true, text_align: :center, text_size: 32, font: TAC::THEME_BOLD_FONT, margin_left: BORDERLESS ? 36 * 3 : 0
|
@header_bar_label = para TAC::NAME, fill: true, text_align: :center, text_size: 32, font: TAC::THEME_BOLD_FONT, margin_left: BORDERLESS ? 36 * 3 : 0
|
||||||
|
|
||||||
@window_controls = flow(width: 36 * 3, height: 1.0) do
|
@window_controls = flow(width: 36 * 3, height: 1.0) do
|
||||||
button get_image("#{TAC::MEDIA_PATH}/icons/minus.png"), tip: "Minimize", image_height: 1.0 do
|
button get_image("#{TAC::MEDIA_PATH}/icons/minus.png"), tip: "Minimize", image_height: 1.0 do
|
||||||
@@ -107,7 +107,7 @@ class Editor < CyberarmEngine::GuiState
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@content = stack(width: window.width - @navigation.style.width, height: 1.0) do
|
@content = stack(fill: true, height: 1.0) do
|
||||||
@chrome = stack(width: 1.0, height: 96) do
|
@chrome = stack(width: 1.0, height: 96) do
|
||||||
@menu_bar = flow(width: 1.0, height: 48, padding: 8) do
|
@menu_bar = flow(width: 1.0, height: 48, padding: 8) do
|
||||||
background 0xff_008000
|
background 0xff_008000
|
||||||
|
|||||||
Reference in New Issue
Block a user