2011-02-24 09:27:21 +00:00
|
|
|
static void VerticalSlider_change(VerticalSlider *self) {
|
|
|
|
if(self->state.position == self->position()) return;
|
|
|
|
self->state.position = self->position();
|
|
|
|
if(self->onChange) self->onChange();
|
|
|
|
}
|
|
|
|
|
2011-03-22 12:56:49 +00:00
|
|
|
Geometry pVerticalSlider::minimumGeometry() {
|
2011-03-23 08:04:37 +00:00
|
|
|
return { 0, 0, 20, 0 };
|
2011-03-22 12:56:49 +00:00
|
|
|
}
|
|
|
|
|
2011-02-24 09:27:21 +00:00
|
|
|
unsigned pVerticalSlider::position() {
|
|
|
|
return (unsigned)gtk_range_get_value(GTK_RANGE(gtkWidget));
|
|
|
|
}
|
|
|
|
|
|
|
|
void pVerticalSlider::setLength(unsigned length) {
|
|
|
|
length += length == 0;
|
Update to v084r05 release.
(note: before the post announcing this release, there had been
a discussion of a performance optimisation that made the Super Scope
emulation a lot faster, but caused problems for the Justifier perpheral)
byuu says:
Spent a good two hours trying things to no avail.
I was trying to allow the CPU to run ahead, and sync on accesses to
$4016/4017/4201/4213, but that doesn't work because the controllers have
access to strobe IObit at will.
The codebase is really starting to get difficult to work with. I am
guessing because the days of massive development are long over, and the
code is starting to age.
Jonas' fix works 98% of the time, but there's still a few missed shots
here and there. So that's not going to work either.
So ... I give up. I've disabled the speed hack, so that it works 100% of
the time.
Did the same for the Super Scope: it may not have the same problem, but
I like consistency and don't feel like taking the chance.
This doesn't affect the mouse, since the mouse does not latch the
counters to indicate its X/Y position.
Speed hit is 92->82fps (accuracy profile), but only for Super Scope and
Justifier games.
But ... at least it works now. Slow and working is better than fast and
broken.
I appreciate the help in researching the issue, Jonas and krom.
Also pulled in phoenix/Makefile, which simplifies ui/Makefile.
Linux port defaults to GTK+ now. I can't get QGtkStyle to look good on
Debian.
2011-12-18 03:19:45 +00:00
|
|
|
gtk_range_set_range(GTK_RANGE(gtkWidget), 0, max(1u, length - 1));
|
2011-08-06 14:03:52 +00:00
|
|
|
gtk_range_set_increments(GTK_RANGE(gtkWidget), 1, length >> 3);
|
2011-02-24 09:27:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void pVerticalSlider::setPosition(unsigned position) {
|
|
|
|
gtk_range_set_value(GTK_RANGE(gtkWidget), position);
|
|
|
|
}
|
|
|
|
|
|
|
|
void pVerticalSlider::constructor() {
|
|
|
|
gtkWidget = gtk_vscale_new_with_range(0, 100, 1);
|
|
|
|
gtk_scale_set_draw_value(GTK_SCALE(gtkWidget), false);
|
|
|
|
g_signal_connect_swapped(G_OBJECT(gtkWidget), "value-changed", G_CALLBACK(VerticalSlider_change), (gpointer)&verticalSlider);
|
2011-09-05 03:48:23 +00:00
|
|
|
|
|
|
|
setLength(verticalSlider.state.length);
|
|
|
|
setPosition(verticalSlider.state.position);
|
|
|
|
}
|
|
|
|
|
|
|
|
void pVerticalSlider::destructor() {
|
|
|
|
gtk_widget_destroy(gtkWidget);
|
|
|
|
}
|
|
|
|
|
|
|
|
void pVerticalSlider::orphan() {
|
|
|
|
destructor();
|
|
|
|
constructor();
|
2011-02-24 09:27:21 +00:00
|
|
|
}
|