/* Copyright 2012 Jan Ove Saltvedt This file is part of KBot. KBot 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 3 of the License, or (at your option) any later version. KBot 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 KBot. If not, see <http://www.gnu.org/licenses/>. */ package com.kbotpro.debuggers; import com.kbotpro.scriptsystem.runnable.Debugger; import com.kbotpro.scriptsystem.wrappers.Player; import com.kbotpro.scriptsystem.events.PaintEventListener; import org.apache.log4j.Logger; import java.awt.*; /** * Created by IntelliJ IDEA. * User: Jan Ove Saltvedt * Date: Oct 9, 2009 * Time: 4:02:16 PM * To change this template use File | Settings | File Templates. */ public class PlayerDebugger extends Debugger implements PaintEventListener { private boolean shallRun; private Player[] cachedPlayers; /** * Gets the name shown in the debugs menu * * @return String containing name */ public String getName() { return "Player Debugger"; } /** * Is called before the debugger starts to check if it can run. * * @return Returns a boolean indicating if the service can be started or not */ public boolean canStart() { return true; //To change body of implemented methods use File | Settings | File Templates. } /** * Is called right before the run() gets called */ public void onStart() { shallRun = true; } /** * Is called to pause debugger. */ public void pause() { //To change body of implemented methods use File | Settings | File Templates. } /** * The debugger is than added to the cleanup queue and thread will be force killed if not deleted within 10 seconds. */ public void stop() { shallRun = false; } /** * You should implement the main loop here. */ public void run() { while(shallRun){ try { if(!game.isLoggedIn()){ sleep(500); return; } Player[] players = super.players.getPlayers(); if(players != null){ cachedPlayers = players; } Thread.sleep(500); } catch (InterruptedException e) { Logger.getRootLogger().error("Exception: ", e); //To change body of catch statement use File | Settings | File Templates. } } } /** * Gets called when the client updates it graphics. * Please do not do anything extremely time consuming in here as it will make the fps go low. * * @param g Graphics to paint on */ public void onRepaint(Graphics g) { if(shallRun) { if(cachedPlayers == null){ g.setColor(Color.red); g.drawString("No players in cache!", 20, 60); return; } g.setColor(Color.green); g.drawString("Players in cache: "+ cachedPlayers.length, 20, 60); g.setColor(Color.BLUE); for(Player player: cachedPlayers){ if(player == null){ continue; } else{ Point p = player.getCenter(); if(p.x != -1 && p.y != -1){ g.fillOval(p.x-2, p.y-2, 4, 4); g.drawString(" "+player.getName(), p.x, p.y); } } } } } }