mirror of https://github.com/bsnes-emu/bsnes.git
Update to v082r01 release.
byuu says: Changelog: - if config file window coordinates are >= 30000, it snaps them back to 128,128; should end the "why aren't windows visible?" posts - updated GUI code to match new phoenix changes - phoenix: Layout and Widget inherit from Sizable; directional layouts make no distinction between widgets and layouts - phoenix: individual widgets / layout can maintain visible/hidden status in spite of their parents' visibility
This commit is contained in:
parent
e8775319c8
commit
d8f9204e18
|
@ -5,6 +5,7 @@ gameboy := gameboy
|
|||
profile := accuracy
|
||||
ui := ui
|
||||
|
||||
# options += console
|
||||
# options += debugger
|
||||
|
||||
# compiler
|
||||
|
@ -25,21 +26,20 @@ else ifeq ($(pgo),optimize)
|
|||
flags += -fprofile-use
|
||||
endif
|
||||
|
||||
flags := $(flags) $(foreach o,$(call strupper,$(options)),-D$o)
|
||||
|
||||
# platform
|
||||
ifeq ($(platform),x)
|
||||
link += -s -ldl -lX11 -lXext
|
||||
else ifeq ($(platform),osx)
|
||||
else ifeq ($(platform),win)
|
||||
link += -mwindows
|
||||
# link += -mconsole
|
||||
link += $(if $(findstring console,$(options)),-mconsole,-mwindows)
|
||||
link += -mthreads -s -luuid -lkernel32 -luser32 -lgdi32 -lcomctl32 -lcomdlg32 -lshell32 -lole32
|
||||
link += -enable-stdcall-fixup -Wl,-enable-auto-import -Wl,-enable-runtime-pseudo-reloc
|
||||
else
|
||||
unknown_platform: help;
|
||||
endif
|
||||
|
||||
flags := $(flags) $(foreach o,$(call strupper,$(options)),-D$o)
|
||||
|
||||
# implicit rules
|
||||
compile = \
|
||||
$(strip \
|
||||
|
|
|
@ -100,6 +100,8 @@ void Widget::setEnabled(bool enabled) { state.enabled = enabled; return p.setEna
|
|||
void Widget::setFocused() { return p.setFocused(); }
|
||||
void Widget::setFont(Font &font) { state.font = &font; return p.setFont(font); }
|
||||
void Widget::setGeometry(const Geometry &geometry) { state.geometry = geometry; return p.setGeometry(geometry); }
|
||||
void Widget::setLayout(Layout &layout) { state.layout = &layout; }
|
||||
void Widget::setParent(Window &parent) { state.parent = &parent; return p.setParent(parent); }
|
||||
void Widget::setVisible(bool visible) { state.visible = visible; return p.setVisible(visible); }
|
||||
bool Widget::visible() { return state.visible; }
|
||||
Widget::Widget() : state(*new State), p(*new pWidget(*this)) { state.abstract = true; p.constructor(); }
|
||||
|
|
|
@ -223,13 +223,21 @@ struct RadioItem : private nall::base_from_member<pRadioItem&>, Action {
|
|||
pRadioItem &p;
|
||||
};
|
||||
|
||||
struct Layout : Object {
|
||||
struct Layout;
|
||||
|
||||
struct Sizable : Object {
|
||||
virtual Geometry minimumGeometry() = 0;
|
||||
virtual void setGeometry(const Geometry &geometry) = 0;
|
||||
virtual void setLayout(Layout &layout) = 0;
|
||||
virtual void setParent(Window &parent) = 0;
|
||||
virtual void setVisible(bool visible = true) = 0;
|
||||
virtual bool visible() = 0;
|
||||
};
|
||||
|
||||
struct Widget : Object {
|
||||
struct Layout : Sizable {
|
||||
};
|
||||
|
||||
struct Widget : Sizable {
|
||||
bool enabled();
|
||||
Font& font();
|
||||
Geometry geometry();
|
||||
|
@ -238,6 +246,8 @@ struct Widget : Object {
|
|||
void setFocused();
|
||||
void setFont(Font &font);
|
||||
void setGeometry(const Geometry &geometry);
|
||||
void setLayout(Layout &layout);
|
||||
void setParent(Window &parent);
|
||||
void setVisible(bool visible = true);
|
||||
bool visible();
|
||||
|
||||
|
|
|
@ -1,20 +1,44 @@
|
|||
void FixedLayout::setParent(Window &parent) {
|
||||
foreach(child, children) {
|
||||
parent.append(*child.widget);
|
||||
child.widget->setGeometry(child.geometry);
|
||||
child.sizable->setParent(parent);
|
||||
child.sizable->setGeometry(child.geometry);
|
||||
}
|
||||
}
|
||||
|
||||
void FixedLayout::append(Widget &widget, const Geometry &geometry) {
|
||||
children.append({ &widget, geometry });
|
||||
void FixedLayout::append(Sizable &sizable, const Geometry &geometry) {
|
||||
children.append({ &sizable, geometry });
|
||||
}
|
||||
|
||||
Geometry FixedLayout::minimumGeometry() {
|
||||
unsigned width = MinimumSize, height = MinimumSize;
|
||||
foreach(child, children) {
|
||||
width = max(width, child.sizable->minimumGeometry().width);
|
||||
height = max(height, child.sizable->minimumGeometry().height);
|
||||
}
|
||||
return { 0, 0, width, height };
|
||||
}
|
||||
|
||||
void FixedLayout::setGeometry(const Geometry &geometry) {
|
||||
}
|
||||
|
||||
void FixedLayout::setLayout(Layout &layout) {
|
||||
this->layout = &layout;
|
||||
}
|
||||
|
||||
void FixedLayout::setVisible(bool visible) {
|
||||
foreach(child, children) child.widget->setVisible(visible);
|
||||
visible_ = visible;
|
||||
foreach(child, children) {
|
||||
child.sizable->setVisible(dynamic_cast<Widget*>(child.sizable) ? child.sizable->visible() : visible);
|
||||
}
|
||||
}
|
||||
|
||||
bool FixedLayout::visible() {
|
||||
if(layout) return visible_ && layout->visible();
|
||||
return visible_;
|
||||
}
|
||||
|
||||
FixedLayout::FixedLayout() {
|
||||
layout = 0;
|
||||
parent = 0;
|
||||
visible_ = true;
|
||||
}
|
||||
|
|
|
@ -1,14 +1,19 @@
|
|||
struct FixedLayout : Layout {
|
||||
void append(Widget &widget, const Geometry &geometry);
|
||||
void append(Sizable &sizable, const Geometry &geometry);
|
||||
Geometry minimumGeometry();
|
||||
void setGeometry(const Geometry &geometry);
|
||||
void setLayout(Layout &layout);
|
||||
void setParent(Window &parent);
|
||||
void setVisible(bool visible);
|
||||
bool visible();
|
||||
FixedLayout();
|
||||
|
||||
//private:
|
||||
Layout *layout;
|
||||
Window *parent;
|
||||
bool visible_;
|
||||
struct Children {
|
||||
Widget *widget;
|
||||
Sizable *sizable;
|
||||
Geometry geometry;
|
||||
};
|
||||
nall::linear_vector<Children> children;
|
||||
|
|
|
@ -1,9 +1,6 @@
|
|||
void HorizontalLayout::append(VerticalLayout &layout, unsigned spacing) {
|
||||
children.append({ &layout, 0, MinimumSize, MinimumSize, spacing });
|
||||
}
|
||||
|
||||
void HorizontalLayout::append(Widget &widget, unsigned width, unsigned height, unsigned spacing) {
|
||||
children.append({ 0, &widget, width, height, spacing });
|
||||
void HorizontalLayout::append(Sizable &sizable, unsigned width, unsigned height, unsigned spacing) {
|
||||
sizable.setLayout(*this);
|
||||
children.append({ &sizable, width, height, spacing });
|
||||
}
|
||||
|
||||
Geometry HorizontalLayout::minimumGeometry() {
|
||||
|
@ -12,8 +9,7 @@ Geometry HorizontalLayout::minimumGeometry() {
|
|||
foreach(child, children) {
|
||||
width += child.spacing;
|
||||
if(child.width == MinimumSize || child.width == MaximumSize) {
|
||||
if(child.layout) width += child.layout->minimumGeometry().width;
|
||||
if(child.widget) width += child.widget->minimumGeometry().width;
|
||||
width += child.sizable->minimumGeometry().width;
|
||||
continue;
|
||||
}
|
||||
width += child.width;
|
||||
|
@ -21,8 +17,7 @@ Geometry HorizontalLayout::minimumGeometry() {
|
|||
|
||||
foreach(child, children) {
|
||||
if(child.height == MinimumSize || child.height == MaximumSize) {
|
||||
if(child.layout) height = max(height, child.layout->minimumGeometry().height);
|
||||
if(child.widget) height = max(height, child.widget->minimumGeometry().height);
|
||||
height = max(height, child.sizable->minimumGeometry().height);
|
||||
continue;
|
||||
}
|
||||
height = max(height, child.height);
|
||||
|
@ -43,8 +38,7 @@ Geometry HorizontalLayout::minimumLayoutGeometry() {
|
|||
}
|
||||
|
||||
if(child.width == MinimumSize) {
|
||||
if(child.layout) width += child.layout->minimumGeometry().width;
|
||||
if(child.widget) width += child.widget->minimumGeometry().width;
|
||||
width += child.sizable->minimumGeometry().width;
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@ -58,8 +52,7 @@ Geometry HorizontalLayout::minimumLayoutGeometry() {
|
|||
}
|
||||
|
||||
if(child.height == MinimumSize) {
|
||||
if(child.layout) height = max(height, child.layout->minimumGeometry().height);
|
||||
if(child.widget) height = max(height, child.widget->minimumGeometry().height);
|
||||
height = max(height, child.sizable->minimumGeometry().height);
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@ -69,18 +62,15 @@ Geometry HorizontalLayout::minimumLayoutGeometry() {
|
|||
return { 0, 0, maximumWidth ? MaximumSize : margin * 2 + width, maximumHeight ? MaximumSize : margin * 2 + height };
|
||||
}
|
||||
|
||||
void HorizontalLayout::setAlignment(double alignment) {
|
||||
this->alignment = max(0.0, min(1.0, alignment));
|
||||
}
|
||||
|
||||
void HorizontalLayout::setGeometry(const Geometry &containerGeometry) {
|
||||
auto children = this->children;
|
||||
foreach(child, children) {
|
||||
if(child.layout) {
|
||||
child.width = child.layout->minimumLayoutGeometry().width;
|
||||
child.height = child.layout->minimumLayoutGeometry().height;
|
||||
}
|
||||
|
||||
if(child.widget) {
|
||||
if(child.width == MinimumSize) child.width = child.widget->minimumGeometry().width;
|
||||
if(child.height == MinimumSize) child.height = child.widget->minimumGeometry().height;
|
||||
}
|
||||
if(child.width == MinimumSize) child.width = child.sizable->minimumGeometry().width;
|
||||
if(child.height == MinimumSize) child.height = child.sizable->minimumGeometry().height;
|
||||
}
|
||||
|
||||
Geometry geometry = containerGeometry;
|
||||
|
@ -105,35 +95,44 @@ void HorizontalLayout::setGeometry(const Geometry &containerGeometry) {
|
|||
foreach(child, children) maximumHeight = max(maximumHeight, child.height);
|
||||
|
||||
foreach(child, children) {
|
||||
unsigned pivot = (maximumHeight - child.height) / 2;
|
||||
unsigned pivot = (maximumHeight - child.height) * alignment;
|
||||
Geometry childGeometry = { geometry.x, geometry.y + pivot, child.width, child.height };
|
||||
|
||||
if(child.layout) child.layout->setGeometry(childGeometry);
|
||||
if(child.widget) child.widget->setGeometry(childGeometry);
|
||||
child.sizable->setGeometry(childGeometry);
|
||||
|
||||
geometry.x += child.width + child.spacing;
|
||||
geometry.width -= child.width + child.spacing;
|
||||
}
|
||||
}
|
||||
|
||||
void HorizontalLayout::setLayout(Layout &layout) {
|
||||
this->layout = &layout;
|
||||
}
|
||||
|
||||
void HorizontalLayout::setMargin(unsigned margin) {
|
||||
this->margin = margin;
|
||||
}
|
||||
|
||||
void HorizontalLayout::setParent(Window &parent) {
|
||||
foreach(child, children) {
|
||||
if(child.layout) child.layout->setParent(parent);
|
||||
if(child.widget) parent.append(*child.widget);
|
||||
child.sizable->setParent(parent);
|
||||
}
|
||||
}
|
||||
|
||||
void HorizontalLayout::setVisible(bool visible) {
|
||||
visible_ = visible;
|
||||
foreach(child, children) {
|
||||
if(child.layout) child.layout->setVisible(visible);
|
||||
if(child.widget) child.widget->setVisible(visible);
|
||||
child.sizable->setVisible(dynamic_cast<Widget*>(child.sizable) ? child.sizable->visible() : visible);
|
||||
}
|
||||
}
|
||||
|
||||
HorizontalLayout::HorizontalLayout() {
|
||||
margin = 0;
|
||||
bool HorizontalLayout::visible() {
|
||||
if(layout) return visible_ && layout->visible();
|
||||
return visible_;
|
||||
}
|
||||
|
||||
HorizontalLayout::HorizontalLayout() {
|
||||
alignment = 0.5;
|
||||
layout = 0;
|
||||
margin = 0;
|
||||
visible_ = true;
|
||||
}
|
||||
|
|
|
@ -1,21 +1,25 @@
|
|||
struct VerticalLayout;
|
||||
|
||||
struct HorizontalLayout : public Layout {
|
||||
void append(VerticalLayout &layout, unsigned spacing = 0);
|
||||
void append(Widget &widget, unsigned width, unsigned height, unsigned spacing = 0);
|
||||
Geometry minimumLayoutGeometry();
|
||||
void append(Sizable &sizable, unsigned width, unsigned height, unsigned spacing = 0);
|
||||
Geometry minimumGeometry();
|
||||
Geometry minimumLayoutGeometry();
|
||||
void setAlignment(double alignment);
|
||||
void setGeometry(const Geometry &geometry);
|
||||
void setLayout(Layout &layout);
|
||||
void setMargin(unsigned margin);
|
||||
void setParent(Window &parent);
|
||||
void setVisible(bool visible);
|
||||
bool visible();
|
||||
HorizontalLayout();
|
||||
|
||||
//private:
|
||||
double alignment;
|
||||
Layout *layout;
|
||||
unsigned margin;
|
||||
bool visible_;
|
||||
struct Children {
|
||||
VerticalLayout *layout;
|
||||
Widget *widget;
|
||||
Sizable *sizable;
|
||||
unsigned width, height, spacing;
|
||||
};
|
||||
nall::linear_vector<Children> children;
|
||||
|
|
|
@ -1,9 +1,6 @@
|
|||
void VerticalLayout::append(HorizontalLayout &layout, unsigned spacing) {
|
||||
children.append({ &layout, 0, MinimumSize, MinimumSize, spacing });
|
||||
}
|
||||
|
||||
void VerticalLayout::append(Widget &widget, unsigned width, unsigned height, unsigned spacing) {
|
||||
children.append({ 0, &widget, width, height, spacing });
|
||||
void VerticalLayout::append(Sizable &sizable, unsigned width, unsigned height, unsigned spacing) {
|
||||
sizable.setLayout(*this);
|
||||
children.append({ &sizable, width, height, spacing });
|
||||
}
|
||||
|
||||
Geometry VerticalLayout::minimumGeometry() {
|
||||
|
@ -11,8 +8,7 @@ Geometry VerticalLayout::minimumGeometry() {
|
|||
|
||||
foreach(child, children) {
|
||||
if(child.width == MinimumSize || child.width == MaximumSize) {
|
||||
if(child.layout) width = max(width, child.layout->minimumGeometry().width);
|
||||
if(child.widget) width = max(width, child.widget->minimumGeometry().width);
|
||||
width = max(width, child.sizable->minimumGeometry().width);
|
||||
continue;
|
||||
}
|
||||
width = max(width, child.width);
|
||||
|
@ -21,8 +17,7 @@ Geometry VerticalLayout::minimumGeometry() {
|
|||
foreach(child, children) {
|
||||
height += child.spacing;
|
||||
if(child.height == MinimumSize || child.height == MaximumSize) {
|
||||
if(child.layout) height += child.layout->minimumGeometry().height;
|
||||
if(child.widget) height += child.widget->minimumGeometry().height;
|
||||
height += child.sizable->minimumGeometry().height;
|
||||
continue;
|
||||
}
|
||||
height += child.height;
|
||||
|
@ -43,8 +38,7 @@ Geometry VerticalLayout::minimumLayoutGeometry() {
|
|||
}
|
||||
|
||||
if(child.width == MinimumSize) {
|
||||
if(child.layout) width = max(width, child.layout->minimumGeometry().width);
|
||||
if(child.widget) width = max(width, child.widget->minimumGeometry().width);
|
||||
width = max(width, child.sizable->minimumGeometry().width);
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@ -58,8 +52,7 @@ Geometry VerticalLayout::minimumLayoutGeometry() {
|
|||
}
|
||||
|
||||
if(child.height == MinimumSize) {
|
||||
if(child.layout) height += child.layout->minimumGeometry().height;
|
||||
if(child.widget) height += child.widget->minimumGeometry().height;
|
||||
height += child.sizable->minimumGeometry().height;
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@ -69,18 +62,15 @@ Geometry VerticalLayout::minimumLayoutGeometry() {
|
|||
return { 0, 0, maximumWidth ? MaximumSize : margin * 2 + width, maximumHeight ? MaximumSize : margin * 2 + height };
|
||||
}
|
||||
|
||||
void VerticalLayout::setAlignment(double alignment) {
|
||||
this->alignment = max(0.0, min(1.0, alignment));
|
||||
}
|
||||
|
||||
void VerticalLayout::setGeometry(const Geometry &containerGeometry) {
|
||||
auto children = this->children;
|
||||
foreach(child, children) {
|
||||
if(child.layout) {
|
||||
child.width = child.layout->minimumLayoutGeometry().width;
|
||||
child.height = child.layout->minimumLayoutGeometry().height;
|
||||
}
|
||||
|
||||
if(child.widget) {
|
||||
if(child.width == MinimumSize) child.width = child.widget->minimumGeometry().width;
|
||||
if(child.height == MinimumSize) child.height = child.widget->minimumGeometry().height;
|
||||
}
|
||||
if(child.width == MinimumSize) child.width = child.sizable->minimumGeometry().width;
|
||||
if(child.height == MinimumSize) child.height = child.sizable->minimumGeometry().height;
|
||||
}
|
||||
|
||||
Geometry geometry = containerGeometry;
|
||||
|
@ -105,35 +95,44 @@ void VerticalLayout::setGeometry(const Geometry &containerGeometry) {
|
|||
foreach(child, children) maximumWidth = max(maximumWidth, child.width);
|
||||
|
||||
foreach(child, children) {
|
||||
unsigned pivot = 0; //(maximumWidth - child.width) / 2;
|
||||
unsigned pivot = (maximumWidth - child.width) * alignment;
|
||||
Geometry childGeometry = { geometry.x + pivot, geometry.y, child.width, child.height };
|
||||
|
||||
if(child.layout) child.layout->setGeometry(childGeometry);
|
||||
if(child.widget) child.widget->setGeometry(childGeometry);
|
||||
child.sizable->setGeometry(childGeometry);
|
||||
|
||||
geometry.y += child.height + child.spacing;
|
||||
geometry.height -= child.height + child.spacing;
|
||||
}
|
||||
}
|
||||
|
||||
void VerticalLayout::setLayout(Layout &layout) {
|
||||
this->layout = &layout;
|
||||
}
|
||||
|
||||
void VerticalLayout::setMargin(unsigned margin) {
|
||||
this->margin = margin;
|
||||
}
|
||||
|
||||
void VerticalLayout::setParent(Window &parent) {
|
||||
foreach(child, children) {
|
||||
if(child.layout) child.layout->setParent(parent);
|
||||
if(child.widget) parent.append(*child.widget);
|
||||
child.sizable->setParent(parent);
|
||||
}
|
||||
}
|
||||
|
||||
void VerticalLayout::setVisible(bool visible) {
|
||||
visible_ = visible;
|
||||
foreach(child, children) {
|
||||
if(child.layout) child.layout->setVisible(visible);
|
||||
if(child.widget) child.widget->setVisible(visible);
|
||||
child.sizable->setVisible(dynamic_cast<Widget*>(child.sizable) ? child.sizable->visible() : visible);
|
||||
}
|
||||
}
|
||||
|
||||
VerticalLayout::VerticalLayout() {
|
||||
margin = 0;
|
||||
bool VerticalLayout::visible() {
|
||||
if(layout) return visible_ && layout->visible();
|
||||
return visible_;
|
||||
}
|
||||
|
||||
VerticalLayout::VerticalLayout() {
|
||||
alignment = 0.0;
|
||||
layout = 0;
|
||||
margin = 0;
|
||||
visible_ = true;
|
||||
}
|
||||
|
|
|
@ -1,21 +1,25 @@
|
|||
struct HorizontalLayout;
|
||||
|
||||
struct VerticalLayout : public Layout {
|
||||
void append(HorizontalLayout &layout, unsigned spacing = 0);
|
||||
void append(Widget &widget, unsigned width, unsigned height, unsigned spacing = 0);
|
||||
void append(Sizable &sizable, unsigned width, unsigned height, unsigned spacing = 0);
|
||||
Geometry minimumGeometry();
|
||||
Geometry minimumLayoutGeometry();
|
||||
void setAlignment(double alignment);
|
||||
void setGeometry(const Geometry &geometry);
|
||||
void setLayout(Layout &layout);
|
||||
void setMargin(unsigned margin);
|
||||
void setParent(Window &parent);
|
||||
void setVisible(bool visible);
|
||||
bool visible();
|
||||
VerticalLayout();
|
||||
|
||||
//private:
|
||||
double alignment;
|
||||
Layout *layout;
|
||||
unsigned margin;
|
||||
bool visible_;
|
||||
struct Children {
|
||||
HorizontalLayout *layout;
|
||||
Widget *widget;
|
||||
Sizable *sizable;
|
||||
unsigned width, height, spacing;
|
||||
};
|
||||
nall::linear_vector<Children> children;
|
||||
|
|
|
@ -100,6 +100,8 @@ struct Widget::State {
|
|||
bool enabled;
|
||||
Font *font;
|
||||
Geometry geometry;
|
||||
Layout *layout;
|
||||
Window *parent;
|
||||
bool visible;
|
||||
|
||||
State() {
|
||||
|
@ -107,6 +109,8 @@ struct Widget::State {
|
|||
enabled = true;
|
||||
font = 0;
|
||||
geometry = { 0, 0, 0, 0 };
|
||||
layout = 0;
|
||||
parent = 0;
|
||||
visible = true;
|
||||
}
|
||||
};
|
||||
|
|
|
@ -186,6 +186,7 @@ struct pWidget : public pObject {
|
|||
virtual void setFocused();
|
||||
virtual void setFont(Font &font);
|
||||
virtual void setGeometry(const Geometry &geometry);
|
||||
void setParent(Window &parent);
|
||||
void setVisible(bool visible);
|
||||
|
||||
pWidget(Widget &widget) : widget(widget) {}
|
||||
|
|
|
@ -15,4 +15,5 @@ void pButton::setText(const string &text) {
|
|||
void pButton::constructor() {
|
||||
gtkWidget = gtk_button_new();
|
||||
g_signal_connect_swapped(G_OBJECT(gtkWidget), "clicked", G_CALLBACK(Button_tick), (gpointer)&button);
|
||||
//g_object_ref((gpointer)gtkWidget);
|
||||
}
|
||||
|
|
|
@ -38,8 +38,20 @@ void pWidget::setGeometry(const Geometry &geometry) {
|
|||
gtk_widget_set_size_request(gtkWidget, width, height);
|
||||
}
|
||||
|
||||
void pWidget::setParent(Window &parent) {
|
||||
parentWindow = &parent.p;
|
||||
|
||||
if(!widget.state.font && parent.state.widgetFont) {
|
||||
setFont(*parent.state.widgetFont);
|
||||
}
|
||||
|
||||
gtk_fixed_put(GTK_FIXED(parent.p.formContainer), gtkWidget, 0, 0);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
||||
void pWidget::setVisible(bool visible) {
|
||||
if(widget.state.abstract) visible = false;
|
||||
if(widget.state.layout && widget.state.layout->visible() == false) visible = false;
|
||||
gtk_widget_set_visible(gtkWidget, visible);
|
||||
}
|
||||
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
/****************************************************************************
|
||||
** Meta object code from reading C++ file 'qt.moc.hpp'
|
||||
**
|
||||
** Created: Mon Aug 8 04:51:19 2011
|
||||
** Created: Mon Aug 22 04:02:58 2011
|
||||
** by: The Qt Meta Object Compiler version 62 (Qt 4.7.0)
|
||||
**
|
||||
** WARNING! All changes made in this file will be lost!
|
||||
|
|
|
@ -219,6 +219,7 @@ struct pWidget : public pObject {
|
|||
void setFocused();
|
||||
void setFont(Font &font);
|
||||
virtual void setGeometry(const Geometry &geometry);
|
||||
void setParent(Window &parent);
|
||||
void setVisible(bool visible);
|
||||
|
||||
pWidget(Widget &widget) : widget(widget) {}
|
||||
|
|
|
@ -23,8 +23,17 @@ void pWidget::setGeometry(const Geometry &geometry) {
|
|||
qtWidget->setGeometry(geometry.x, geometry.y, geometry.width, geometry.height);
|
||||
}
|
||||
|
||||
void pWidget::setParent(Window &parent) {
|
||||
if(!widget.state.font && parent.state.widgetFont) {
|
||||
setFont(*parent.state.widgetFont);
|
||||
}
|
||||
qtWidget->setParent(parent.p.qtContainer);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
||||
void pWidget::setVisible(bool visible) {
|
||||
if(widget.state.abstract) visible = false;
|
||||
if(widget.state.layout && widget.state.layout->visible() == false) visible = false;
|
||||
qtWidget->setVisible(visible);
|
||||
}
|
||||
|
||||
|
|
|
@ -18,4 +18,5 @@ void pButton::setParent(Window &parent) {
|
|||
SetWindowLongPtr(hwnd, GWLP_USERDATA, (LONG_PTR)&button);
|
||||
setDefaultFont();
|
||||
setText(button.state.text);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -51,4 +51,5 @@ void pCanvas::setParent(Window &parent) {
|
|||
if(hwnd) DestroyWindow(hwnd);
|
||||
hwnd = CreateWindow(L"phoenix_canvas", L"", WS_CHILD | WS_VISIBLE, 0, 0, 0, 0, parent.p.hwnd, (HMENU)id, GetModuleHandle(0), 0);
|
||||
SetWindowLongPtr(hwnd, GWLP_USERDATA, (LONG_PTR)&canvas);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -30,4 +30,5 @@ void pCheckBox::setParent(Window &parent) {
|
|||
setDefaultFont();
|
||||
if(checkBox.state.checked) setChecked(true);
|
||||
setText(checkBox.state.text);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -46,4 +46,5 @@ void pComboBox::setParent(Window &parent) {
|
|||
setDefaultFont();
|
||||
foreach(text, comboBox.state.text) append(text);
|
||||
setSelection(comboBox.state.selection);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -128,4 +128,5 @@ void pHexEdit::setParent(Window &parent) {
|
|||
|
||||
windowProc = (LRESULT CALLBACK (*)(HWND, UINT, LPARAM, WPARAM))GetWindowLongPtr(hwnd, GWLP_WNDPROC);
|
||||
SetWindowLongPtr(hwnd, GWLP_WNDPROC, (LONG_PTR)HexEdit_windowProc);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -30,4 +30,5 @@ void pHorizontalScrollBar::setParent(Window &parent) {
|
|||
unsigned position = horizontalScrollBar.state.position;
|
||||
setLength(horizontalScrollBar.state.length);
|
||||
setPosition(position);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -31,4 +31,5 @@ void pHorizontalSlider::setParent(Window &parent) {
|
|||
unsigned position = horizontalSlider.state.position;
|
||||
setLength(horizontalSlider.state.length);
|
||||
setPosition(position);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -19,6 +19,7 @@ void pLabel::setParent(Window &parent) {
|
|||
SetWindowLongPtr(hwnd, GWLP_USERDATA, (LONG_PTR)&label);
|
||||
setDefaultFont();
|
||||
setText(label.state.text);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
||||
static LRESULT CALLBACK Label_windowProc(HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam) {
|
||||
|
|
|
@ -37,4 +37,5 @@ void pLineEdit::setParent(Window &parent) {
|
|||
setDefaultFont();
|
||||
setEditable(lineEdit.state.editable);
|
||||
setText(lineEdit.state.text);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -131,4 +131,5 @@ void pListView::setParent(Window &parent) {
|
|||
foreach(checked, listView.state.checked, n) setChecked(n, checked);
|
||||
if(listView.state.selected) setSelection(listView.state.selection);
|
||||
autoSizeColumns();
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -17,4 +17,5 @@ void pProgressBar::setParent(Window &parent) {
|
|||
SendMessage(hwnd, PBM_SETRANGE, 0, MAKELPARAM(0, 100));
|
||||
SendMessage(hwnd, PBM_SETSTEP, MAKEWPARAM(1, 0), 0);
|
||||
setPosition(progressBar.state.position);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -35,4 +35,5 @@ void pRadioBox::setParent(Window &parent) {
|
|||
setDefaultFont();
|
||||
if(radioBox.state.checked) setChecked();
|
||||
setText(radioBox.state.text);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -50,4 +50,5 @@ void pTextEdit::setParent(Window &parent) {
|
|||
setCursorPosition(textEdit.state.cursorPosition);
|
||||
setEditable(textEdit.state.editable);
|
||||
setText(textEdit.state.text);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -30,4 +30,5 @@ void pVerticalScrollBar::setParent(Window &parent) {
|
|||
unsigned position = verticalScrollBar.state.position;
|
||||
setLength(verticalScrollBar.state.length);
|
||||
setPosition(position);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -31,4 +31,5 @@ void pVerticalSlider::setParent(Window &parent) {
|
|||
unsigned position = verticalSlider.state.position;
|
||||
setLength(verticalSlider.state.length);
|
||||
setPosition(position);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
|
|
@ -9,6 +9,7 @@ void pViewport::constructor() {
|
|||
void pViewport::setParent(Window &parent) {
|
||||
hwnd = CreateWindow(L"phoenix_viewport", L"", WS_CHILD | WS_VISIBLE | WS_DISABLED, 0, 0, 0, 0, parent.p.hwnd, (HMENU)id, GetModuleHandle(0), 0);
|
||||
SetWindowLongPtr(hwnd, GWLP_USERDATA, (LONG_PTR)&viewport);
|
||||
widget.setVisible(widget.visible());
|
||||
}
|
||||
|
||||
static LRESULT CALLBACK Viewport_windowProc(HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam) {
|
||||
|
|
|
@ -29,6 +29,7 @@ void pWidget::setGeometry(const Geometry &geometry) {
|
|||
|
||||
void pWidget::setVisible(bool visible) {
|
||||
if(widget.state.abstract) visible = false;
|
||||
if(widget.state.layout && widget.state.layout->visible() == false) visible = false;
|
||||
ShowWindow(hwnd, visible ? SW_SHOWNORMAL : SW_HIDE);
|
||||
}
|
||||
|
||||
|
@ -49,4 +50,5 @@ void pWidget::setParent(Window &parent) {
|
|||
if(hwnd) DestroyWindow(hwnd);
|
||||
hwnd = CreateWindow(L"phoenix_label", L"", WS_CHILD, 0, 0, 0, 0, parent.p.hwnd, (HMENU)id, GetModuleHandle(0), 0);
|
||||
SetWindowLongPtr(hwnd, GWLP_USERDATA, (LONG_PTR)&widget);
|
||||
widget.setVisible(false);
|
||||
}
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
namespace SNES {
|
||||
namespace Info {
|
||||
static const char Name[] = "bsnes";
|
||||
static const char Version[] = "082";
|
||||
static const char Version[] = "082.01";
|
||||
static const unsigned SerializerVersion = 21;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -199,8 +199,12 @@ bool snes_load_cartridge_super_game_boy(
|
|||
if(rom_data) SNES::cartridge.rom.copy(rom_data, rom_size);
|
||||
string xmlrom = (rom_xml && *rom_xml) ? string(rom_xml) : SNESCartridge(rom_data, rom_size).xmlMemoryMap;
|
||||
if(dmg_data) {
|
||||
string xmldmg = (dmg_xml && *dmg_xml) ? string(dmg_xml) : GameBoyCartridge(dmg_data, dmg_size).xml;
|
||||
GameBoy::cartridge.load(xmldmg, dmg_data, dmg_size);
|
||||
//GameBoyCartridge needs to modify dmg_data (for MMM01 emulation); so copy data
|
||||
uint8_t *data = new uint8_t[dmg_size];
|
||||
memcpy(data, dmg_data, dmg_size);
|
||||
string xmldmg = (dmg_xml && *dmg_xml) ? string(dmg_xml) : GameBoyCartridge(data, dmg_size).xml;
|
||||
GameBoy::cartridge.load(xmldmg, data, dmg_size);
|
||||
delete[] data;
|
||||
}
|
||||
SNES::cartridge.load(SNES::Cartridge::Mode::SuperGameBoy, { xmlrom, "" });
|
||||
SNES::system.power();
|
||||
|
|
|
@ -22,7 +22,7 @@ void Console::create() {
|
|||
controlLayout.append(traceSMP, 120, 0 );
|
||||
controlLayout.append(spacer, 120, ~0 );
|
||||
controlLayout.append(clearConsole, 120, 0 );
|
||||
layout.append(controlLayout );
|
||||
layout.append(controlLayout, 0, ~0 );
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, layout.minimumGeometry().width + 585, 350 });
|
||||
|
||||
|
|
|
@ -17,7 +17,7 @@ void CPUDebugger::create() {
|
|||
controlLayout.append(stepOver, 80, 0 );
|
||||
controlLayout.append(proceed, 80, 0 );
|
||||
controlLayout.append(spacer, 80, ~0 );
|
||||
layout.append(controlLayout );
|
||||
layout.append(controlLayout, 0, ~0 );
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, layout.minimumGeometry().width + 300, 220 });
|
||||
|
||||
|
|
|
@ -17,7 +17,7 @@ void SMPDebugger::create() {
|
|||
controlLayout.append(stepOver, 80, 0 );
|
||||
controlLayout.append(proceed, 80, 0 );
|
||||
controlLayout.append(spacer, 80, ~0 );
|
||||
layout.append(controlLayout );
|
||||
layout.append(controlLayout, 0, ~0 );
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, layout.minimumGeometry().width + 300, 220 });
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ void BreakpointEditor::create() {
|
|||
breakpointLayout[n].append(valueBox[n], 30, 0, 5);
|
||||
breakpointLayout[n].append(typeBox[n], 0, 0, 5);
|
||||
breakpointLayout[n].append(sourceBox[n], 0, 0 );
|
||||
layout.append(breakpointLayout[n], n < Breakpoints - 1 ? 5 : 0);
|
||||
layout.append(breakpointLayout[n], ~0, 0, n < Breakpoints - 1 ? 5 : 0);
|
||||
}
|
||||
|
||||
append(layout);
|
||||
|
|
|
@ -20,7 +20,7 @@ void MemoryEditor::create() {
|
|||
controlLayout.append(gotoBox, 80, 0 );
|
||||
controlLayout.append(refreshButton, 80, 0 );
|
||||
controlLayout.append(spacer, 80, ~0 );
|
||||
layout.append(controlLayout );
|
||||
layout.append(controlLayout, 0, ~0 );
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, layout.minimumGeometry().width + 475, 230 });
|
||||
|
||||
|
|
|
@ -17,7 +17,7 @@ void AboutWindow::create() {
|
|||
layout.append(canvas, 720, 180);
|
||||
informationLayout.append(spacer, ~0, 0);
|
||||
informationLayout.append(information, 0, 0);
|
||||
layout.append(informationLayout);
|
||||
layout.append(informationLayout, ~0, 0);
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, layout.minimumGeometry().width, layout.minimumGeometry().height });
|
||||
}
|
||||
|
|
|
@ -12,7 +12,7 @@ void FileBrowser::create() {
|
|||
pathLayout.append(pathBox, ~0, 0, 5);
|
||||
pathLayout.append(browseButton, sq, sq, 5);
|
||||
pathLayout.append(upButton, sq, sq );
|
||||
layout.append(pathLayout, 5);
|
||||
layout.append(pathLayout, ~0, 0, 5);
|
||||
layout.append(contentsBox, ~0, ~0 );
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, 640, layout.minimumGeometry().height + 400 });
|
||||
|
|
|
@ -16,14 +16,14 @@ void SingleSlotLoader::create() {
|
|||
baseLayout.append(baseLabel, 40, 0, 5);
|
||||
baseLayout.append(basePath, ~0, 0, 5);
|
||||
baseLayout.append(baseBrowse, sq, sq );
|
||||
layout.append(baseLayout, 5);
|
||||
layout.append(baseLayout, ~0, 0, 5);
|
||||
slotLayout.append(slotLabel, 40, 0, 5);
|
||||
slotLayout.append(slotPath, ~0, 0, 5);
|
||||
slotLayout.append(slotBrowse, sq, sq );
|
||||
layout.append(slotLayout, 5);
|
||||
layout.append(slotLayout, ~0, 0, 5);
|
||||
controlLayout.append(spacer, ~0, 0 );
|
||||
controlLayout.append(okButton, 80, 0 );
|
||||
layout.append(controlLayout);
|
||||
layout.append(controlLayout, ~0, 0 );
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, 480, layout.minimumGeometry().height });
|
||||
|
||||
|
@ -111,18 +111,18 @@ void DoubleSlotLoader::create() {
|
|||
baseLayout.append(baseLabel, 40, 0, 5);
|
||||
baseLayout.append(basePath, ~0, 0, 5);
|
||||
baseLayout.append(baseBrowse, sq, sq );
|
||||
layout.append(baseLayout, 5);
|
||||
layout.append(baseLayout, ~0, 0, 5);
|
||||
slotALayout.append(slotALabel, 40, 0, 5);
|
||||
slotALayout.append(slotAPath, ~0, 0, 5);
|
||||
slotALayout.append(slotABrowse, sq, sq );
|
||||
layout.append(slotALayout, 5);
|
||||
layout.append(slotALayout, ~0, 0, 5);
|
||||
slotBLayout.append(slotBLabel, 40, 0, 5);
|
||||
slotBLayout.append(slotBPath, ~0, 0, 5);
|
||||
slotBLayout.append(slotBBrowse, sq, sq );
|
||||
layout.append(slotBLayout, 5);
|
||||
layout.append(slotBLayout, ~0, 0, 5);
|
||||
controlLayout.append(spacer, ~0, 0 );
|
||||
controlLayout.append(okButton, 80, 0 );
|
||||
layout.append(controlLayout);
|
||||
layout.append(controlLayout, ~0, 0 );
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, 480, layout.minimumGeometry().height });
|
||||
|
||||
|
|
|
@ -188,11 +188,21 @@ void Application::loadGeometry() {
|
|||
foreach(window, windows) {
|
||||
lstring position;
|
||||
position.split(",", window->position);
|
||||
Geometry geom = window->geometry();
|
||||
window->setGeometry({
|
||||
Geometry configGeometry = {
|
||||
(signed)integer(position[0]), (signed)integer(position[1]),
|
||||
geom.width, geom.height
|
||||
//(unsigned)decimal(position[2]), (unsigned)decimal(position[3])
|
||||
(unsigned)decimal(position[2]), (unsigned)decimal(position[3])
|
||||
};
|
||||
Geometry windowGeometry = window->geometry();
|
||||
|
||||
//Windows places minimized windows offscreen at 32000,32000
|
||||
//this is a fix for older releases that did not compensate for this
|
||||
if(configGeometry.x >= 30000) configGeometry.x = 128;
|
||||
if(configGeometry.y >= 30000) configGeometry.y = 128;
|
||||
|
||||
window->setGeometry({
|
||||
configGeometry.x, configGeometry.y,
|
||||
windowGeometry.width, windowGeometry.height
|
||||
//configGeometry.width, configGeometry.height
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
|
@ -31,7 +31,7 @@ void AdvancedSettings::create() {
|
|||
|
||||
panelLayout.setMargin(5);
|
||||
panelLayout.append(panel, SettingsWindow::PanelWidth, ~0, 5);
|
||||
panelLayout.append(layout);
|
||||
panelLayout.append(layout, ~0, ~0);
|
||||
|
||||
layout.append(title, ~0, 0, 5);
|
||||
|
||||
|
@ -41,18 +41,18 @@ void AdvancedSettings::create() {
|
|||
driverLayout.append(audioDriverLabel, 0, 0, 5);
|
||||
driverLayout.append(audioDriverBox, ~0, 0, 5);
|
||||
driverLayout.append(inputDriverLabel, 0, 0, 5);
|
||||
driverLayout.append(inputDriverBox, ~0, 0 );
|
||||
layout.append(driverLayout, 5);
|
||||
layout.append(focusPolicyLabel, ~0, 0 );
|
||||
driverLayout.append(inputDriverBox, ~0, 0);
|
||||
layout.append(driverLayout, ~0, 0, 5);
|
||||
layout.append(focusPolicyLabel, ~0, 0);
|
||||
focusPolicyLayout.append(focusPolicyPause, ~0, 0, 5);
|
||||
focusPolicyLayout.append(focusPolicyIgnore, ~0, 0, 5);
|
||||
focusPolicyLayout.append(focusPolicyAllow, ~0, 0);
|
||||
layout.append(focusPolicyLayout, 5);
|
||||
layout.append(focusPolicyLayout, ~0, 0, 5);
|
||||
layout.append(compositorPolicyLabel, ~0, 0);
|
||||
compositorPolicyLayout.append(compositorPolicyNever, ~0, 0, 5);
|
||||
compositorPolicyLayout.append(compositorPolicyFullScreen, ~0, 0, 5);
|
||||
compositorPolicyLayout.append(compositorPolicyAlways, ~0, 0);
|
||||
layout.append(compositorPolicyLayout);
|
||||
layout.append(compositorPolicyLayout, ~0, 0);
|
||||
|
||||
layout.append(spacer, ~0, ~0);
|
||||
settingsWindow.append(panelLayout);
|
||||
|
|
|
@ -13,24 +13,24 @@ void AudioSettings::create() {
|
|||
|
||||
panelLayout.setMargin(5);
|
||||
panelLayout.append(panel, SettingsWindow::PanelWidth, ~0, 5);
|
||||
panelLayout.append(layout);
|
||||
panelLayout.append(layout, ~0, ~0);
|
||||
|
||||
layout.append(title, ~0, 0, 5);
|
||||
|
||||
frequencyLayout.append(frequencyLabel, 70, 0);
|
||||
frequencyLayout.append(frequencyValue, 60, 0);
|
||||
frequencyLayout.append(frequencySlider, ~0, 0);
|
||||
layout.append(frequencyLayout);
|
||||
layout.append(frequencyLayout, ~0, 0);
|
||||
|
||||
volumeLayout.append(volumeLabel, 70, 0);
|
||||
volumeLayout.append(volumeValue, 60, 0);
|
||||
volumeLayout.append(volumeSlider, ~0, 0);
|
||||
layout.append(volumeLayout);
|
||||
layout.append(volumeLayout, ~0, 0);
|
||||
|
||||
balanceLayout.append(balanceLabel, 70, 0);
|
||||
balanceLayout.append(balanceValue, 60, 0);
|
||||
balanceLayout.append(balanceSlider, ~0, 0);
|
||||
layout.append(balanceLayout);
|
||||
layout.append(balanceLayout, ~0, 0);
|
||||
|
||||
layout.append(spacer, ~0, ~0);
|
||||
settingsWindow.append(panelLayout);
|
||||
|
|
|
@ -23,7 +23,7 @@ void InputSettings::create() {
|
|||
|
||||
panelLayout.setMargin(5);
|
||||
panelLayout.append(panel, SettingsWindow::PanelWidth, ~0, 5);
|
||||
panelLayout.append(layout);
|
||||
panelLayout.append(layout, ~0, ~0);
|
||||
|
||||
layout.append(title, ~0, 0, 5);
|
||||
|
||||
|
@ -31,7 +31,7 @@ void InputSettings::create() {
|
|||
selectionLayout.append(portBox, ~0, 0, 5);
|
||||
selectionLayout.append(deviceLabel, 0, 0, 5);
|
||||
selectionLayout.append(deviceBox, ~0, 0);
|
||||
layout.append(selectionLayout, 5);
|
||||
layout.append(selectionLayout, ~0, 0, 5);
|
||||
|
||||
layout.append(mappingList, ~0, ~0, 5);
|
||||
|
||||
|
@ -40,7 +40,7 @@ void InputSettings::create() {
|
|||
controlLayout.append(customButton3, 100, 0, 5);
|
||||
controlLayout.append(spacer, ~0, 0);
|
||||
controlLayout.append(clearButton, 80, 0);
|
||||
layout.append(controlLayout);
|
||||
layout.append(controlLayout, ~0, 0);
|
||||
|
||||
settingsWindow.append(panelLayout);
|
||||
clearButton.setEnabled(false);
|
||||
|
|
|
@ -22,7 +22,7 @@ void VideoSettings::create() {
|
|||
|
||||
panelLayout.setMargin(5);
|
||||
panelLayout.append(panel, SettingsWindow::PanelWidth, ~0, 5);
|
||||
panelLayout.append(layout);
|
||||
panelLayout.append(layout, ~0, ~0);
|
||||
|
||||
layout.append(title, ~0, 0, 5);
|
||||
|
||||
|
@ -30,21 +30,21 @@ void VideoSettings::create() {
|
|||
brightnessLayout.append(brightnessLabel, 80, 0 );
|
||||
brightnessLayout.append(brightnessValue, 50, 0 );
|
||||
brightnessLayout.append(brightnessSlider, ~0, 0 );
|
||||
layout.append(brightnessLayout );
|
||||
layout.append(brightnessLayout, ~0, 0 );
|
||||
contrastLayout.append(contrastLabel, 80, 0 );
|
||||
contrastLayout.append(contrastValue, 50, 0 );
|
||||
contrastLayout.append(contrastSlider, ~0, 0 );
|
||||
layout.append(contrastLayout );
|
||||
layout.append(contrastLayout, ~0, 0 );
|
||||
gammaLayout.append(gammaLabel, 80, 0 );
|
||||
gammaLayout.append(gammaValue, 50, 0 );
|
||||
gammaLayout.append(gammaSlider, ~0, 0 );
|
||||
layout.append(gammaLayout );
|
||||
layout.append(gammaLayout, ~0, 0 );
|
||||
layout.append(gammaRampCheck, ~0, 0, 5);
|
||||
layout.append(fullscreenLabel, ~0, 0 );
|
||||
fullscreenLayout.append(fullscreenCenter, ~0, 0, 5);
|
||||
fullscreenLayout.append(fullscreenScale, ~0, 0, 5);
|
||||
fullscreenLayout.append(fullscreenStretch, ~0, 0 );
|
||||
layout.append(fullscreenLayout);
|
||||
layout.append(fullscreenLayout, ~0, 0 );
|
||||
|
||||
layout.append(spacer, ~0, ~0);
|
||||
settingsWindow.append(panelLayout);
|
||||
|
|
|
@ -14,7 +14,7 @@ void CheatDatabase::create() {
|
|||
controlLayout.append(unselectAllButton, 100, 0 );
|
||||
controlLayout.append(spacerWidget, ~0, 0 );
|
||||
controlLayout.append(okButton, 80, 0 );
|
||||
layout.append(controlLayout );
|
||||
layout.append(controlLayout, ~0, 0 );
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, 600, layout.minimumGeometry().height + 350 });
|
||||
|
||||
|
|
|
@ -1,5 +1,48 @@
|
|||
CheatEditor cheatEditor;
|
||||
|
||||
void CheatEditor::create() {
|
||||
setTitle("Cheat Editor");
|
||||
application.addWindow(this, "CheatEditor", "160,160");
|
||||
|
||||
cheatList.setHeaderText("Slot", "Code", "Description");
|
||||
cheatList.setHeaderVisible();
|
||||
cheatList.setCheckable();
|
||||
codeLabel.setText("Code(s):");
|
||||
descLabel.setText("Description:");
|
||||
findButton.setText("Find Codes ...");
|
||||
clearAllButton.setText("Clear All");
|
||||
clearButton.setText("Clear");
|
||||
|
||||
layout.setMargin(5);
|
||||
layout.append(cheatList, ~0, ~0, 5);
|
||||
codeLayout.append(codeLabel, 80, 0, 5);
|
||||
codeLayout.append(codeEdit, ~0, 0 );
|
||||
layout.append(codeLayout, ~0, 0, 5);
|
||||
descLayout.append(descLabel, 80, 0, 5);
|
||||
descLayout.append(descEdit, ~0, 0 );
|
||||
layout.append(descLayout, ~0, 0, 5);
|
||||
controlLayout.append(findButton, 100, 0 );
|
||||
controlLayout.append(spacerWidget, ~0, 0 );
|
||||
controlLayout.append(clearAllButton, 80, 0, 5);
|
||||
controlLayout.append(clearButton, 80, 0 );
|
||||
layout.append(controlLayout, ~0, 0 );
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, 480, layout.minimumGeometry().height + 250 });
|
||||
|
||||
synchronize();
|
||||
|
||||
cheatList.onChange = { &CheatEditor::synchronize, this };
|
||||
cheatList.onTick = { &CheatEditor::toggle, this };
|
||||
codeEdit.onChange = descEdit.onChange = { &CheatEditor::bind, this };
|
||||
findButton.onTick = { &CheatDatabase::findCodes, &cheatDatabase };
|
||||
clearAllButton.onTick = { &CheatEditor::clearAll, this };
|
||||
clearButton.onTick = { &CheatEditor::clear, this };
|
||||
|
||||
onClose = []() {
|
||||
cheatDatabase.setVisible(false);
|
||||
};
|
||||
}
|
||||
|
||||
void CheatEditor::load() {
|
||||
SNES::cheat.reset();
|
||||
cheatList.reset();
|
||||
|
@ -78,49 +121,6 @@ void CheatEditor::save() {
|
|||
cheatList.autoSizeColumns();
|
||||
}
|
||||
|
||||
void CheatEditor::create() {
|
||||
setTitle("Cheat Editor");
|
||||
application.addWindow(this, "CheatEditor", "160,160");
|
||||
|
||||
cheatList.setHeaderText("Slot", "Code", "Description");
|
||||
cheatList.setHeaderVisible();
|
||||
cheatList.setCheckable();
|
||||
codeLabel.setText("Code(s):");
|
||||
descLabel.setText("Description:");
|
||||
findButton.setText("Find Codes ...");
|
||||
clearAllButton.setText("Clear All");
|
||||
clearButton.setText("Clear");
|
||||
|
||||
layout.setMargin(5);
|
||||
layout.append(cheatList, ~0, ~0, 5);
|
||||
codeLayout.append(codeLabel, 80, 0, 5);
|
||||
codeLayout.append(codeEdit, ~0, 0 );
|
||||
layout.append(codeLayout, 5);
|
||||
descLayout.append(descLabel, 80, 0, 5);
|
||||
descLayout.append(descEdit, ~0, 0 );
|
||||
layout.append(descLayout, 5);
|
||||
controlLayout.append(findButton, 100, 0 );
|
||||
controlLayout.append(spacerWidget, ~0, 0 );
|
||||
controlLayout.append(clearAllButton, 80, 0, 5);
|
||||
controlLayout.append(clearButton, 80, 0 );
|
||||
layout.append(controlLayout);
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, 480, layout.minimumGeometry().height + 250 });
|
||||
|
||||
synchronize();
|
||||
|
||||
cheatList.onChange = { &CheatEditor::synchronize, this };
|
||||
cheatList.onTick = { &CheatEditor::toggle, this };
|
||||
codeEdit.onChange = descEdit.onChange = { &CheatEditor::bind, this };
|
||||
findButton.onTick = { &CheatDatabase::findCodes, &cheatDatabase };
|
||||
clearAllButton.onTick = { &CheatEditor::clearAll, this };
|
||||
clearButton.onTick = { &CheatEditor::clear, this };
|
||||
|
||||
onClose = []() {
|
||||
cheatDatabase.setVisible(false);
|
||||
};
|
||||
}
|
||||
|
||||
void CheatEditor::synchronize() {
|
||||
findButton.setEnabled(SNES::cartridge.loaded());
|
||||
clearAllButton.setEnabled(SNES::cartridge.loaded());
|
||||
|
|
|
@ -15,12 +15,12 @@ void StateManager::create() {
|
|||
layout.append(stateList, ~0, ~0, 5);
|
||||
descLayout.append(descLabel, 80, 0, 5);
|
||||
descLayout.append(descEdit, ~0, 0 );
|
||||
layout.append(descLayout, 5);
|
||||
layout.append(descLayout, ~0, 0, 5);
|
||||
controlLayout.append(spacer, 0, 0 );
|
||||
controlLayout.append(loadButton, 80, 0, 5);
|
||||
controlLayout.append(saveButton, 80, 0, 5);
|
||||
controlLayout.append(eraseButton, 80, 0 );
|
||||
layout.append(controlLayout );
|
||||
layout.append(controlLayout, ~0, 0 );
|
||||
append(layout);
|
||||
setGeometry({ 0, 0, 480, layout.minimumGeometry().height + 250 });
|
||||
|
||||
|
|
Loading…
Reference in New Issue