project_files/Android-build/SDL-android-project/src/org/hedgewars/hedgeroid/netplay/TickHandler.java
author Medo <smaxein@googlemail.com>
Tue, 24 Jul 2012 16:57:48 +0200
changeset 7355 5673e95ef647
child 7476 2fb781bbdd51
permissions -rw-r--r--
Hedgeroid: Misguided attempts at getting the connection lifecycle right. Committing this because it basically runs this way, so i might want to revert to it later :)

package org.hedgewars.hedgeroid.netplay;

import android.os.Handler;
import android.os.Looper;
import android.os.Message;

/**
 * This class handles regularly calling a specified runnable
 * on the looper provided in the constructor. The first call
 * occurs without delay (though still via the looper), all
 * following calls are delayed by (approximately) the interval.
 * The interval can be changed at any time, which will cause
 * an immediate execution of the runnable again.
 */
class TickHandler extends Handler {
	private final Runnable callback;
	private int messageId;
	private long interval;
	private boolean running;
	
	public TickHandler(Looper looper, long interval, Runnable callback) {
		super(looper);
		this.callback = callback;
		this.interval = interval;
	}
	
	public synchronized void stop() {
		messageId++;
		running = false;
	}
	
	public synchronized void start() {
		messageId++;
		sendMessage(obtainMessage(messageId));
		running = true;
	}
	
	public synchronized void setInterval(long interval) {
		this.interval = interval;
		if(running) {
			start();
		}
	}
	
	@Override
	public synchronized void handleMessage(Message msg) {
		if(msg.what == messageId) {
			callback.run();
		}
		if(msg.what == messageId) {
			sendMessageDelayed(obtainMessage(messageId), interval);
		}
	}
}