simplified SeekBar

This commit is contained in:
Martin Wagner
2022-03-13 19:10:05 +01:00
parent d5c148205f
commit 3a72ce83ca

View File

@@ -3018,7 +3018,6 @@ class SeekBar(Gtk.Box):
super().__init__(hexpand=True, margin_start=6, margin_right=6) super().__init__(hexpand=True, margin_start=6, margin_right=6)
self._client=client self._client=client
self._update=True self._update=True
self._jumped=False
# labels # labels
attrs=Pango.AttrList() attrs=Pango.AttrList()
@@ -3037,9 +3036,12 @@ class SeekBar(Gtk.Box):
self._adjustment=self._scale.get_adjustment() self._adjustment=self._scale.get_adjustment()
# connect # connect
elapsed_event_box.connect("button-release-event", self._on_elapsed_button_release_event) elapsed_dict={1: Gtk.ScrollType.STEP_BACKWARD, 3: Gtk.ScrollType.STEP_FORWARD}
rest_event_box.connect("button-release-event", self._on_rest_button_release_event) rest_dict={1: Gtk.ScrollType.STEP_FORWARD, 3: Gtk.ScrollType.STEP_BACKWARD}
elapsed_event_box.connect("button-release-event", self._on_label_button_release_event, elapsed_dict)
rest_event_box.connect("button-release-event", self._on_label_button_release_event, rest_dict)
self._scale.connect("change-value", self._on_change_value) self._scale.connect("change-value", self._on_change_value)
self._scale.connect("value-changed", self._on_value_changed)
self._scale.connect("scroll-event", lambda *args: True) # disable mouse wheel self._scale.connect("scroll-event", lambda *args: True) # disable mouse wheel
self._scale.connect("button-press-event", self._on_scale_button_press_event) self._scale.connect("button-press-event", self._on_scale_button_press_event)
self._scale.connect("button-release-event", self._on_scale_button_release_event) self._scale.connect("button-release-event", self._on_scale_button_release_event)
@@ -3055,13 +3057,9 @@ class SeekBar(Gtk.Box):
def _refresh(self, emitter, elapsed, duration): def _refresh(self, emitter, elapsed, duration):
self.set_sensitive(True) self.set_sensitive(True)
if duration > 0: if duration > 0:
if elapsed > duration: # fix display error
elapsed=duration
self._adjustment.set_upper(duration) self._adjustment.set_upper(duration)
if self._update: if self._update:
self._scale.set_value(elapsed) self._scale.set_value(elapsed)
self._elapsed.set_text(str(Duration(elapsed)))
self._rest.set_text(str(Duration(elapsed-duration)))
self._scale.set_fill_level(elapsed) self._scale.set_fill_level(elapsed)
else: else:
self._disable() self._disable()
@@ -3071,52 +3069,34 @@ class SeekBar(Gtk.Box):
self.set_sensitive(False) self.set_sensitive(False)
self._scale.set_fill_level(0) self._scale.set_fill_level(0)
self._scale.set_range(0, 0) self._scale.set_range(0, 0)
self._elapsed.set_text(str(Duration()))
self._rest.set_text(str(Duration()))
def _on_scale_button_press_event(self, widget, event): def _on_scale_button_press_event(self, widget, event):
if event.button == 1 and event.type == Gdk.EventType.BUTTON_PRESS: self._update=False
self._update=False
self._scale.set_has_origin(False)
elif event.button == 3 and event.type == Gdk.EventType.BUTTON_PRESS:
self._jumped=False
def _on_scale_button_release_event(self, widget, event): def _on_scale_button_release_event(self, widget, event):
if event.button == 1: self._update=True
self._update=True self._client.seekcur(self._scale.get_value())
self._scale.set_has_origin(True)
if self._jumped: # actual seek
self._client.seekcur(self._scale.get_value())
self._jumped=False
else: # restore state
status=self._client.status()
self._refresh(None, float(status["elapsed"]), float(status["duration"]))
def _on_change_value(self, range, scroll, value): # value is inaccurate (can be above upper limit) def _on_change_value(self, scale, scroll, value):
if (scroll == Gtk.ScrollType.STEP_BACKWARD or scroll == Gtk.ScrollType.STEP_FORWARD or if scroll in (Gtk.ScrollType.STEP_BACKWARD, Gtk.ScrollType.STEP_FORWARD , Gtk.ScrollType.PAGE_BACKWARD, Gtk.ScrollType.PAGE_FORWARD):
scroll == Gtk.ScrollType.PAGE_BACKWARD or scroll == Gtk.ScrollType.PAGE_FORWARD):
self._client.seekcur(value) self._client.seekcur(value)
elif scroll == Gtk.ScrollType.JUMP:
duration=self._adjustment.get_upper() def _on_value_changed(self, scale):
if value > duration: # fix display error duration=self._adjustment.get_upper()
elapsed=duration value=self._scale.get_value()
else: if value > duration: # fix display error
elapsed=value elapsed=duration
else:
elapsed=value
if duration > 0:
self._elapsed.set_text(str(Duration(elapsed))) self._elapsed.set_text(str(Duration(elapsed)))
self._rest.set_text(str(Duration(elapsed-duration))) self._rest.set_text(str(Duration(duration-elapsed)))
self._jumped=True else:
self._elapsed.set_text(str(Duration()))
self._rest.set_text(str(Duration()))
def _on_elapsed_button_release_event(self, widget, event): def _on_label_button_release_event(self, widget, event, scroll_type):
if event.button == 1: self._scale.emit("move-slider", scroll_type.get(event.button, Gtk.ScrollType.NONE))
self._client.seekcur("-"+str(self._adjustment.get_property("step-increment")))
elif event.button == 3:
self._client.seekcur("+"+str(self._adjustment.get_property("step-increment")))
def _on_rest_button_release_event(self, widget, event):
if event.button == 1:
self._client.seekcur("+"+str(self._adjustment.get_property("step-increment")))
elif event.button == 3:
self._client.seekcur("-"+str(self._adjustment.get_property("step-increment")))
def _on_state(self, emitter, state): def _on_state(self, emitter, state):
if state == "stop": if state == "stop":