mirror of
https://github.com/amyinspace/MagicSetEditor2.git
synced 2026-06-10 04:57:00 -04:00
Allow "Default" in slider fields
This commit is contained in:
+53
-47
@@ -15,12 +15,12 @@
|
||||
#include <util/rotation.hpp>
|
||||
#include <gfx/gfx.hpp>
|
||||
#include <wx/dcbuffer.h>
|
||||
|
||||
bool DropDownList::slider_loaded;
|
||||
wxBitmap DropDownList::slider_left;
|
||||
wxBitmap DropDownList::slider_right;
|
||||
wxBitmap DropDownList::slider_center;
|
||||
wxBitmap DropDownList::slider_tick;
|
||||
|
||||
bool DropDownList::slider_loaded;
|
||||
wxBitmap DropDownList::slider_left;
|
||||
wxBitmap DropDownList::slider_right;
|
||||
wxBitmap DropDownList::slider_center;
|
||||
wxBitmap DropDownList::slider_tick;
|
||||
|
||||
// ----------------------------------------------------------------------------- : DropDownHider
|
||||
|
||||
@@ -110,15 +110,15 @@ void DropDownList::show(bool in_place, wxPoint pos, RealRect* rect) {
|
||||
}
|
||||
// determine dropdown size
|
||||
RealSize border_size(2,2); // GetClientSize() - GetSize(), assume 1px borders
|
||||
RealSize size;
|
||||
if (is_slider) {
|
||||
size.height = 70 + marginH * 2;
|
||||
size.width = min(1000.0, max(150.0, max(100.0 + count, item_size.width + marginW * 2)));
|
||||
} else {
|
||||
RealSize size;
|
||||
if (is_slider) {
|
||||
size.height = 70 + marginH * 2;
|
||||
size.width = min(1000.0, max(150.0, max(100.0 + count, item_size.width + marginW * 2)));
|
||||
} else {
|
||||
int line_count = 0;
|
||||
for (size_t i = 0; i < count; ++i) if (lineBelow(i)) line_count += 1;
|
||||
size.height = item_size.height * count + marginH * 2 + line_count;
|
||||
size.width = item_size.width + marginW * 2;
|
||||
size.height = item_size.height * count + marginH * 2 + line_count;
|
||||
size.width = item_size.width + marginW * 2;
|
||||
}
|
||||
// determine placement
|
||||
int parent_height = 0;
|
||||
@@ -316,37 +316,40 @@ void DropDownList::draw(DC& dc) {
|
||||
dc.SetPen(*wxTRANSPARENT_PEN);
|
||||
dc.SetBrush(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW));
|
||||
dc.DrawRectangle(0, 0, cs.x, cs.y);
|
||||
dc.SetFont(*wxNORMAL_FONT);
|
||||
dc.SetFont(*wxNORMAL_FONT);
|
||||
if (is_slider) {
|
||||
// If it's a slider, draw the slider
|
||||
cs = GetClientSize();
|
||||
dc.SetPen(*wxBLACK_PEN);
|
||||
// If it's a slider, draw the slider
|
||||
cs = GetClientSize();
|
||||
dc.SetPen(*wxBLACK_PEN);
|
||||
dc.SetFont(wxFont(12, wxFONTFAMILY_SWISS, wxFONTSTYLE_NORMAL, wxFONTWEIGHT_BOLD, false, _("Arial")));
|
||||
|
||||
String first_item = capitalize(itemText(0));
|
||||
if (first_item == _("Default")) first_item = capitalize(itemText(1));
|
||||
String last_item = capitalize(itemText(count-1));
|
||||
int first_text_width;
|
||||
dc.GetTextExtent(capitalize(itemText(0)), &first_text_width, nullptr);
|
||||
int last_text_width;
|
||||
dc.GetTextExtent(capitalize(itemText(count-1)), &last_text_width, nullptr);
|
||||
dc.DrawText(capitalize(itemText(0)), marginW + 4, 14);
|
||||
dc.DrawText(capitalize(itemText(count-1)), cs.x - marginW - 4 - last_text_width, 14);
|
||||
|
||||
int slider_start = first_text_width + marginW + 16;
|
||||
int slider_end = cs.x - (last_text_width + marginW + 16);
|
||||
dc.DrawBitmap(slider_left, slider_start, 14);
|
||||
dc.GetTextExtent(first_item, &first_text_width, nullptr);
|
||||
dc.GetTextExtent(last_item, &last_text_width, nullptr);
|
||||
dc.DrawText(first_item, marginW + 8, 14);
|
||||
dc.DrawText(last_item, cs.x - last_text_width - marginW - 8, 14);
|
||||
|
||||
int slider_start = first_text_width + marginW + 20;
|
||||
int slider_end = cs.x - last_text_width - marginW - 20;
|
||||
dc.DrawBitmap(slider_left, slider_start, 14);
|
||||
for (size_t i = slider_start + 19; i < slider_end - 19; i+=19) {
|
||||
dc.DrawBitmap(slider_center, i, 14);
|
||||
}
|
||||
dc.DrawBitmap(slider_right, slider_end - 19, 14);
|
||||
|
||||
int selected_index = selected_item < 0 ? 0 : selected_item;
|
||||
int slider_pos = round((double)selected_index/(count - 1) * (slider_end - slider_start)) + slider_start;
|
||||
dc.DrawBitmap(slider_tick, slider_pos - 7, 9); // -7 cause the bitmap is 15 pixels wide
|
||||
|
||||
dc.DrawBitmap(slider_center, i, 14);
|
||||
}
|
||||
dc.DrawBitmap(slider_right, slider_end - 19, 14);
|
||||
int selected_index = selected_item < 0 ? 0 : selected_item;
|
||||
int slider_pos = round((double)selected_index/(count-1) * (slider_end - slider_start)) + slider_start;
|
||||
dc.DrawBitmap(slider_tick, slider_pos - 7, 9); // -7 cause the slider_tick bitmap is 15 pixels wide
|
||||
|
||||
int selected_text_width;
|
||||
dc.GetTextExtent(capitalize(itemText(selected_index)), &selected_text_width, nullptr);
|
||||
dc.DrawText(capitalize(itemText(selected_index)), slider_pos - selected_text_width/2, 44);
|
||||
dc.GetTextExtent(capitalize(itemText(selected_index)), &selected_text_width, nullptr);
|
||||
dc.DrawText(capitalize(itemText(selected_index)), slider_pos - selected_text_width/2, 44);
|
||||
|
||||
dc.SetFont(*wxNORMAL_FONT);
|
||||
} else {
|
||||
} else {
|
||||
// If it's not a slider, draw the list of items
|
||||
int y = marginH - visible_start;
|
||||
for (size_t i = 0; i < count; ++i) {
|
||||
@@ -424,21 +427,24 @@ void DropDownList::onMotion(wxMouseEvent& ev) {
|
||||
ev.Skip();
|
||||
return;
|
||||
}
|
||||
// find selected item
|
||||
// find selected item
|
||||
size_t count = itemCount();
|
||||
if (is_slider) {
|
||||
String first_item = capitalize(itemText(0));
|
||||
if (first_item == _("Default")) first_item = capitalize(itemText(1));
|
||||
String last_item = capitalize(itemText(count-1));
|
||||
int first_text_width;
|
||||
GetTextExtent(capitalize(itemText(0)), &first_text_width, nullptr);
|
||||
int last_text_width;
|
||||
GetTextExtent(capitalize(itemText(count - 1)), &last_text_width, nullptr);
|
||||
int slider_start = first_text_width + marginW + 16;
|
||||
int slider_end = cs.x - (last_text_width + marginW + 16);
|
||||
int slider_pos = ev.GetX();
|
||||
if (slider_pos < slider_start) slider_pos = slider_start;
|
||||
if (slider_pos > slider_end) slider_pos = slider_end;
|
||||
int selected_item = round(((double)(slider_pos - slider_start)) / (slider_end - slider_start) * (count - 1));
|
||||
GetTextExtent(first_item, &first_text_width, nullptr);
|
||||
GetTextExtent(last_item, &last_text_width, nullptr);
|
||||
int slider_start = first_text_width + marginW + 20;
|
||||
int slider_end = cs.x - last_text_width - marginW - 20;
|
||||
int slider_pos = ev.GetX();
|
||||
if (slider_pos < slider_start) slider_pos = slider_start;
|
||||
if (slider_pos > slider_end) slider_pos = slider_end;
|
||||
int selected_item = round(((double)(slider_pos - slider_start)) / (slider_end - slider_start) * (count-1));
|
||||
selectItem(selected_item);
|
||||
} else {
|
||||
} else {
|
||||
int startY = marginH - visible_start;
|
||||
for (size_t i = 0; i < count; ++i) {
|
||||
int endY = startY + (int)item_size.height;
|
||||
@@ -570,4 +576,4 @@ BEGIN_EVENT_TABLE(DropDownList,wxPopupWindow)
|
||||
EVT_LEAVE_WINDOW (DropDownList::onMouseLeave)
|
||||
EVT_MOUSEWHEEL (DropDownList::onMouseWheel)
|
||||
EVT_SCROLLWIN (DropDownList::onScroll)
|
||||
END_EVENT_TABLE ()
|
||||
END_EVENT_TABLE ()
|
||||
|
||||
Reference in New Issue
Block a user