/*
* Simbad - Robot Simulator Copyright (C) 2004 Louis Hugues
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free Software
* Foundation; either version 2 of the License, or (at your option) any later
* version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with
* this program; if not, write to the Free Software Foundation, Inc., 59 Temple
* Place, Suite 330, Boston, MA 02111-1307 USA
*
* -----------------------------------------------------------------------------
* $Author: sioulseuguh $
* $Date: 2005/04/25 17:58:17 $
* $Revision: 1.2 $
* $Source: /cvsroot/simbad/src/simbad/demo/PushBallsDemo.java,v $
*/
package simbad.demo;
import javax.vecmath.Vector3d;
import javax.vecmath.Color3f;
import javax.vecmath.Vector3f;
import simbad.sim.*;
/** Shows a robot pushing balls.
* This demo shows simple physical interactions between agents.
*/
public class PushBallsDemo extends Demo {
public class Robot extends Agent {
public Robot(Vector3d position, String name) {
super(position, name);
//RobotFactory.addCameraSensor(this);
}
/** Initialize Agent's Behavior */
public void initBehavior() {
setTranslationalVelocity(0.5);
}
public void contactWith(SimpleAgent a){
// System.out.println(getName()+" interacts with "+a.getName());
}
/** Perform one step of Agent's Behavior */
public void performBehavior() {
// if (collisionDetected()&& (! interactionDetected()))
// moveToStartPosition();
if ((getCounter() % 80) == 0) {
setRotationalVelocity(Math.PI / 2 * (0.5 - Math.random()));
setTranslationalVelocity(0.5);
}
}
}
public PushBallsDemo() {
showAxis(false);
setUsePhysics(true);
setWorldSize(12);
boxColor = new Color3f(0.6f,0.5f,.3f);
add(new Box(new Vector3d(-5,0,0),new Vector3f(0.1f,1,10),this));
add(new Box(new Vector3d(0,0,-5),new Vector3f(10,1,0.1f),this));
add(new Box(new Vector3d(5,0,0),new Vector3f(0.1f,1,10),this));
add(new Box(new Vector3d(0,0,5),new Vector3f(10,1,0.1f),this));
add(new Robot(new Vector3d(0, 0, 0), "Maradonna"));
// Set up the ball agents
int n = 1;
Color3f c ;
for (int x = -n; x <= n; x++) {
for (int z = -n; z <= n; z++) {
if (!((x == 0) && (z == 0))) {
c = new Color3f(x/(float)n, 0.3f, z/(float)n);
add(new BallAgent(new Vector3d(x, 0, z), "ball", c,0.25f,0.25f));
}
}
}
}
}