From 0d4fd89688cbd8f613294c4041745608050c01d3 Mon Sep 17 00:00:00 2001 From: Heikki Halmetoja Date: Thu, 12 Dec 2024 23:03:57 +0200 Subject: [PATCH] Fixed Maschine Jam step sequencer resolution options - no longer limited by number of channels --- .../command/trigger/GroupButtonCommand.java | 33 ++++++++++--------- 1 file changed, 17 insertions(+), 16 deletions(-) diff --git a/src/main/java/de/mossgrabers/controller/ni/maschine/core/command/trigger/GroupButtonCommand.java b/src/main/java/de/mossgrabers/controller/ni/maschine/core/command/trigger/GroupButtonCommand.java index fdb73466e..c9abc3e1c 100644 --- a/src/main/java/de/mossgrabers/controller/ni/maschine/core/command/trigger/GroupButtonCommand.java +++ b/src/main/java/de/mossgrabers/controller/ni/maschine/core/command/trigger/GroupButtonCommand.java @@ -65,6 +65,15 @@ public void execute (final ButtonEvent event, final int velocity) return; } + // Set sequencer resolution + if (this.surface.isPressed (ButtonID.GROOVE)) + { + final IView active = this.surface.getViewManager ().getActive (); + if (active instanceof final AbstractSequencerView sequencerView) + sequencerView.setResolutionIndex (this.index); + return; + } + final ITrackBank trackBank = this.model.getCurrentTrackBank (); final ITrack track = trackBank.getItem (this.index); if (!track.doesExist ()) @@ -110,15 +119,6 @@ public void execute (final ButtonEvent event, final int velocity) return; } - // Set sequencer resolution - if (this.surface.isPressed (ButtonID.GROOVE)) - { - final IView active = this.surface.getViewManager ().getActive (); - if (active instanceof final AbstractSequencerView sequencerView) - sequencerView.setResolutionIndex (this.index); - return; - } - // Track selection or group expansion track.selectOrExpandGroup (); } @@ -152,6 +152,14 @@ public int getButtonColor () return MaschineColorManager.COLOR_BLACK; } + if (this.surface.isPressed (ButtonID.GROOVE)) + { + final IView active = this.surface.getViewManager ().getActive (); + if (active instanceof final AbstractSequencerView sequencerView) + return sequencerView.getResolutionIndex () == this.index ? MaschineColorManager.COLOR_GREEN : MaschineColorManager.COLOR_DARK_GREY; + return MaschineColorManager.COLOR_BLACK; + } + final ITrack track = trackBank.getItem (this.index); if (!track.doesExist ()) @@ -166,13 +174,6 @@ public int getButtonColor () if (this.surface.isPressed (ButtonID.RECORD)) return track.isRecArm () ? MaschineColorManager.COLOR_RED : MaschineColorManager.COLOR_DARK_GREY; - if (this.surface.isPressed (ButtonID.GROOVE)) - { - final IView active = this.surface.getViewManager ().getActive (); - if (active instanceof final AbstractSequencerView sequencerView) - return sequencerView.getResolutionIndex () == this.index ? MaschineColorManager.COLOR_GREEN : MaschineColorManager.COLOR_DARK_GREY; - return MaschineColorManager.COLOR_BLACK; - } // Track selection return ((MaschineColorManager) this.model.getColorManager ()).dimOrHighlightColor (track.getColor (), track.isSelected ());