com.googlecode.blaisemath.graph.layout.IterativeGraphLayoutService Maven / Gradle / Ivy
package com.googlecode.blaisemath.graph.layout;
/*
* #%L
* BlaiseGraphTheory (v3)
* --
* Copyright (C) 2009 - 2019 Elisha Peterson
* --
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/
import com.google.common.util.concurrent.AbstractScheduledService;
import com.google.common.util.concurrent.MoreExecutors;
import com.google.common.util.concurrent.Service;
import java.util.concurrent.TimeUnit;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
* Service used for executing iterative graph layouts on a background thread.
* The "runOneIteration" method is assumed to be run from a background or alternate thread.
*/
class IterativeGraphLayoutService extends AbstractScheduledService {
private static final Logger LOG = Logger.getLogger(IterativeGraphLayoutService.class.getName());
/** Default time between layout iterations. */
private static final int DEFAULT_DELAY = 10;
/** Delay between loops */
private final int loopDelay;
/** Manages the layout */
private final IterativeGraphLayoutManager manager;
IterativeGraphLayoutService(IterativeGraphLayoutManager mgr) {
this(mgr, DEFAULT_DELAY);
}
@SuppressWarnings("SameParameterValue")
IterativeGraphLayoutService(IterativeGraphLayoutManager mgr, int loopDelay) {
this.manager = mgr;
this.loopDelay = loopDelay;
addListener(new Listener() {
@Override
public void failed(Service.State from, Throwable failure) {
LOG.log(Level.SEVERE, "Layout service failed", failure);
}
}, MoreExecutors.newDirectExecutorService());
}
//region PROPERTIES
boolean isLayoutActive() {
return isRunning();
}
//endregion
@Override
protected synchronized void runOneIteration() {
try {
manager.runOneLoop();
} catch (InterruptedException x) {
LOG.log(Level.FINE, "Background layout interrupted", x);
// restore interrupt after bypassing update
Thread.currentThread().interrupt();
}
}
@Override
protected Scheduler scheduler() {
return Scheduler.newFixedDelaySchedule(0, loopDelay, TimeUnit.MILLISECONDS);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy