Ir al contenido principal

Design Patterns in Java (Behavioral) - Command Pattern

Command Pattern

  • Encapsulate request as an object
  • Object-oriented callback
  • Decouple sender from processor
  • Often used for "undo" action

Design

  • Object per command
  • Command interface
    • execute method
    • undo method
  • Use reflexion

Main




public static void main(String[] args) {
//Receiver - (Action)
LightReceiver lc = new LightReceiver();
//OnCommand = concrete command
Command c = new OnCommand(lc);
//Invoker - (Execute)
SwitchInvoker si = new SwitchInvoker();
si.storeAndExecute(c);
}

Receiver

public class LightReceiver {
public void on(){
System.out.println("Light is on");
}
public void off(){
System.out.println("Light is off");
}
}

Invoker


public class SwitchInvoker {
public void storeAndExecute( Command command){
command.execute();
}
}
Command



public interface Command {
public void execute();
}

Specific Command


public class OnCommand implements Command {
LightReceiver lg;
public OnCommand(LightReceiver lg){
this.lg = lg;
} 
@Override
public void execute() {
lg.on();
}
}

Adding STATE

Specific Command with State

In this case is another command but the Invoker state equals

Receiver


public class ToogleLightReceiver {
boolean isOn = false;
public boolean isOn(){
return isOn;
}
public void toogle(){
if(isOn)
off();
else
on();
isOn = !isOn;
}
public void on(){
System.out.println("Light is on");
}
public void off(){
System.out.println("Light is off");
}
}

New Command with state


public class ToggleCommand implements Command {
ToogleLightReceiver lg;
public ToggleCommand(ToogleLightReceiver lg){
this.lg = lg;
} 
@Override
public void execute() {
lg.toogle();
}
}

Main


public static void main(String[] args) {
//Receiver
ToogleLightReceiver lc = new ToogleLightReceiver();
//Invoker
SwitchInvoker si = new SwitchInvoker();
//OnCommand = concrete command
Command c = new ToggleCommand(lc);
si.storeAndExecute(c);
si.storeAndExecute(c);
}



Comentarios

Entradas populares de este blog

Android - Basic Steps (Service)

Service Run in the main thread of the hosting application Android can kill the Service if need the resources Purpose Supporting inter-application method execution Performing background processing Start a Service Call Context.startService(Intent intent)\ To call from a Fragment use getActivity().getApplicationContext().startService( intentService); Executing the service After call startService(...)  In the Service is executed the method onStartCommand(...) If the method returns the constant START_NOT_STICKY then Android will not restart the service automatically if the the process is killedp Foreground To execute the service foreground call the method startForeground() Use this if the user is aware of the process Bind to a Service Call the method Context.bindService( Intent service ServiceConnection con int flags ) Send Toast from the Service On the method onStartCommand receive the message   ...

Android - Basic Steps (Location & Maps)

Location Is composed by Latitude Longitude Time-stamp Accuracy Altitude Speed Bearing LocationProvider Types: Network  Wifi access points Cell phone towers GPS Passive Piggyback on the readings requested by other application Permissions Network  android.permission.ACCESS_COARSE_LOCATION android.permission.ACCESS_FINE_LOCATION GPS android.permission.ACCESS_FINE_LOCATION Passive Provider android.permission.ACCESS_FINE_LOCATION LocationManager System service for accessing location data getSystemService( Context.LOCATION_SERVICE ) Functions Determine the last known user location Register for location update Register to receive intents when the device nears or move away from a given geographic area LocationListener Defines callbacks methods that are called when Location or LocationProvider status change. Methods onLocationChanged(...) onProviderDisabled(...) onProviderEnabled(...) onStatusChan...

Android - Basic Steps (Sensors)

Sensors There are three types: Motion Position Environment ServiceManager Get a reference with   getSystemService(Context.SENSOR_SERVICE) Get a specific sensor SensorManager.getDefaultSensor(int type) Sensor Types Sensor.TYPE_ACCELEROMETER Sensor.TYPE_MAGNETIC_FIELD Sensor.TYPE_PRESSURE SensorEventListener Interface for SensorEvent callback When the accuracy has changed onAccuracyChanged() When has a new value onSensorChanged() SensorManager To register or unregister SensorEvents registerListener() unregisterListener() SensorEvents Include Data is sensor Sensor Type time-stamp Accuracy Measurement data Filters Low-pass Deemphasize transient force changes Emphasize constant force components Example Carpenter's level High-pass Emphasize transient force changes Deemphasize  constant force components Example Percussion instrument