Skip to content

Commit

Permalink
Merge pull request #547 from saalfeldlab/fix/1.4.2
Browse files Browse the repository at this point in the history
Fix/1.4.2
  • Loading branch information
cmhulbert authored Aug 14, 2024
2 parents f2e05c1 + c16570c commit 2ad1166
Show file tree
Hide file tree
Showing 7 changed files with 10 additions and 25 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -31,9 +31,6 @@ import org.janelia.saalfeldlab.fx.util.InvokeOnJavaFXApplicationThread
import org.janelia.saalfeldlab.paintera.PainteraBaseKeys
import org.janelia.saalfeldlab.paintera.config.input.KeyAndMouseBindings
import org.janelia.saalfeldlab.paintera.control.actions.AllowedActions
import org.janelia.saalfeldlab.paintera.control.modes.NavigationTool.activeViewer
import org.janelia.saalfeldlab.paintera.control.modes.NavigationTool.mode
import org.janelia.saalfeldlab.paintera.control.modes.NavigationTool.removeFrom
import org.janelia.saalfeldlab.paintera.control.tools.REQUIRES_ACTIVE_VIEWER
import org.janelia.saalfeldlab.paintera.control.tools.Tool
import org.janelia.saalfeldlab.paintera.control.tools.ToolBarItem
Expand Down Expand Up @@ -86,14 +83,15 @@ interface ToolMode : SourceMode {
}
}

fun switchTool(tool: Tool?) : Job? {
fun switchTool(tool: Tool?): Job? {
if (activeTool == tool)
return null

LOG.debug { "Switch from $activeTool to $tool" }

/* Deactivate off the main thread */
val deactivateJob = CoroutineScope(Dispatchers.Default).launch {
LOG.trace {"Deactivated $activeTool"}
LOG.trace { "Deactivated $activeTool" }
activeTool?.deactivate()
}

Expand All @@ -105,15 +103,15 @@ interface ToolMode : SourceMode {
showToolBars()
tool?.activate()
activeTool = tool
LOG.trace {"Activated $activeTool"}
LOG.trace { "Activated $activeTool" }
}

deactivateJob.invokeOnCompletion {
/* If the mode was changed before we can activate, don't activate anymore */
if (paintera.baseView.activeModeProperty.value == this@ToolMode)
activateJob.start()
}
return activateJob
return activateJob
}

private fun showToolBars(show: Boolean = true) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -71,10 +71,6 @@ object NavigationControlMode : AbstractToolMode() {

override val tools: ObservableList<Tool> = FXCollections.observableArrayList(NavigationTool)

override fun enter() {
super.enter()
switchTool(NavigationTool)
}
}

object NavigationTool : ViewerTool() {
Expand Down Expand Up @@ -206,14 +202,14 @@ object NavigationTool : ViewerTool() {

fun scrollActions(translationController: TranslationController): ActionSet {
data class ScrollSpeedStruct(val name: String, val speed: Double, val keysInit: Action<ScrollEvent>.() -> Unit)
return painteraActionSet("scroll translate along normal", NavigationActionType.Slice) {
return painteraActionSet("scroll-translate-along-normal", NavigationActionType.Slice) {
listOf(
ScrollSpeedStruct("default", DEFAULT) { keysDown() },
ScrollSpeedStruct("fast", FAST) { keysDown(KeyCode.SHIFT) },
ScrollSpeedStruct("slow", SLOW) { keysDown(KeyCode.CONTROL) }
).map { (actionName, speed, keysInit) ->
ScrollEvent.SCROLL {
name = actionName
name = "${this@painteraActionSet.name}.$actionName"
onAction {
val delta = -ControlUtils.getBiggestScroll(it).sign * speed
translationController.translate(0.0, 0.0, delta)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -206,9 +206,6 @@ object RawSourceMode : AbstractToolMode() {
old?.viewer()?.removeActionSet(actionSet)
new?.viewer()?.installActionSet(actionSet)
}

/* set the currently activeTool for this viewer */
switchTool(activeTool ?: NavigationTool)
}

override fun enter() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,6 @@ class ShapeInterpolationMode<D : IntegerType<D>>(val controller: ShapeInterpolat
controller.apply {
if (!isControllerActive && source.currentMask == null && source.isApplyingMaskProperty.not().get()) {
modifyFragmentAlpha()
switchTool(shapeInterpolationTool)
enterShapeInterpolation(viewerAndTransforms.viewer())
shapeInterpolationTool.apply {
requestEmbedding(currentDepth)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,6 @@ object ViewLabelMode : AbstractToolMode() {
old?.viewer()?.removeActionSet(actionSet)
new?.viewer()?.installActionSet(actionSet)
}

/* set the currently activeTool for this viewer */
switchTool(activeTool ?: NavigationTool)
}

override fun enter() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,7 @@ abstract class ViewerTool(protected val mode: ToolMode? = null) : Tool, ToolBarI
fun removeFromAll() {
synchronized(this) {
installedInto.forEach { (node, actions) ->
LOG.debug { "removing $this" }
LOG.debug { "removing $this from all nodes" }
actions.removeIf { actionSet ->
node.removeActionSet(actionSet)
true
Expand All @@ -125,7 +125,7 @@ abstract class ViewerTool(protected val mode: ToolMode? = null) : Tool, ToolBarI
fun removeFrom(node: Node) {
synchronized(this) {
installedInto[node]?.let { actions ->
LOG.debug { "removing $this" }
LOG.debug { "removing $this from node $node" }
actions.removeIf { actionSet ->
node.removeActionSet(actionSet)
true
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ internal class ShapeInterpolationTool(
mutableListOf(
*shapeInterpolationActions().filterNotNull().toTypedArray(),
cancelShapeInterpolationTask(),
*NavigationTool.actionSets.filter { "rotat" !in it.name }.toTypedArray() //Kinda ugly to filter like this, but this is a weird case. Still, should do better
*NavigationTool.actionSets.toTypedArray() //Kinda ugly to filter like this, but this is a weird case. Still, should do better
)
}

Expand All @@ -71,8 +71,6 @@ internal class ShapeInterpolationTool(
disabledTranslationActions.forEach { disabledViewer.installActionSet(it) }
}
/* Activate, but we want to bind it to our activeViewer bindings instead of the default. */
NavigationTool.activate()
NavigationTool.activeViewerProperty.unbind()
NavigationTool.activeViewerProperty.bind(activeViewerProperty)
}

Expand Down

0 comments on commit 2ad1166

Please sign in to comment.