Beispiel #1
0
        public void watchExercise(String gameId)
        {
            JSONPacket packet = new JSONPacket("pantau/register");

            this.gameId = gameId;
            packet.setParameter("gameid", gameId);
            modifiedCommunication.broadcast(packet);
            modifiedCommunication.listenWatchConfirmationAsync(this);
            parent.setWatchingEnabled(true);
        }
 public override void stopExercise(bool force)
 {
     base.stopExercise(force);
     foreach (IPAddress watcher in watchers)
     {
         JSONPacket packet = new JSONPacket("pantau/state");
         packet.setParameter("state", "STOP");
         parent.writeLog(LogLevel.Info, "Kirim ke pemantau " + watcher + " pesan " + packet);
         communication.send(watcher, packet, UDPCommunication.IN_PORT);
     }
 }
 public override void startExercise()
 {
     base.startExercise();
     foreach (IPAddress watcher in watchers)
     {
         JSONPacket packet     = new JSONPacket("pantau/state");
         string     teamGroups = "";
         for (int i = 0; i < prajurits.Count; i++)
         {
             teamGroups += prajurits[i].group;
         }
         packet.setParameter("state", "START/" + teamGroups);
         parent.writeLog(LogLevel.Info, "Kirim ke pemantau " + watcher + " pesan " + packet);
         communication.send(watcher, packet, UDPCommunication.IN_PORT);
     }
 }
Beispiel #4
0
        public virtual void handlePacket(IPAddress address, JSONPacket inPacket, bool updateUI)
        {
            try
            {
                this.recorder.record(address, inPacket.ToString());
                String type = inPacket.getParameter("type");
                if (type.Equals("register"))
                {
                    if (inPacket.getParameter("gameid").Equals(gameId))
                    {
                        if (state == State.REGISTRATION)
                        {
                            int nomerUrut = Prajurit.findPrajuritIndexByNomerInduk(prajurits, inPacket.getParameter("nomerInduk"));
                            if (nomerUrut == -1)
                            {
                                // Register
                                nomerUrut = prajurits.Count + 1;
                                Prajurit newPrajurit = new Prajurit(nomerUrut, inPacket.getParameter("nomerInduk"), address, "A", null);
                                prajuritDatabase.retrieveNameFromDatabase(newPrajurit);
                                prajurits.Add(newPrajurit);
                                if (updateUI)
                                {
                                    parent.refreshTable();
                                }
                            }
                            else
                            {
                                nomerUrut = nomerUrut + 1;
                            }

                            // Confirm
                            JSONPacket outPacket = new JSONPacket("confirm");
                            outPacket.setParameter("androidId", "" + nomerUrut);
                            communication.send(address, outPacket);
                        }
                        else
                        {
                            parent.writeLog(LogLevel.Warn, "Registration from " + address + " is ignored as we are not in registration phase");
                        }
                    }
                    else
                    {
                        parent.writeLog(LogLevel.Warn, "Registration from " + address + " with game id " + inPacket.getParameter("gameid") + " is ignored");
                    }
                }
                else if (type.Equals("event/update"))
                {
                    if (inPacket.getParameter("gameid").Equals(gameId))
                    {
                        if (state != State.IDLE)
                        {
                            int      index    = Int32.Parse(inPacket.getParameter("androidId")) - 1;
                            Prajurit prajurit = prajurits[index];
                            prajurit.setLocation(inPacket.getParameter("location"));
                            prajurit.heading  = Double.Parse(inPacket.getParameter("heading"));
                            prajurit.accuracy = Int32.Parse(inPacket.getParameter("accuracy"));
                            string[] prajuritState = inPacket.getParameter("state").Split('/');
                            prajurit.state   = (prajuritState[0].Equals("alive") ? Prajurit.State.NORMAL : Prajurit.State.DEAD);
                            prajurit.posture = (prajuritState[1].Equals("stand") ? Prajurit.Posture.STAND : Prajurit.Posture.CRAWL);
                            if (inPacket.getParameter("action").Equals("hit"))
                            {
                                int idSenjata = Int32.Parse(inPacket.getParameter("idsenjata"));
                                int counter   = Int32.Parse(inPacket.getParameter("counter"));
                                if (state == State.REGISTRATION)
                                {
                                    // Registration phase, senjata assign to prajurit.
                                    Senjata newSenjata = new Senjata(idSenjata, prajurit, counter, this.initialAmmo);
                                    prajurit.senjata = newSenjata;
                                    senjatas.Add(newSenjata.idSenjata, newSenjata);
                                }
                                else if (state == State.EXERCISE)
                                {
                                    Senjata senjataPenembak = senjatas[idSenjata];
                                    senjataPenembak.currentCounter = counter;
                                    if (senjataPenembak.getRemainingAmmo() > 0)
                                    {
                                        prajurit.state = Prajurit.State.HIT;
                                        communication.send(prajurit.ipAddress, new JSONPacket("killed"));
                                    }
                                }
                                parent.refreshTable();
                            }
                            else if (inPacket.getParameter("action").Equals("shoot"))
                            {
                                prajurit.state = Prajurit.State.SHOOT;
                            }
                            if (updateUI)
                            {
                                parent.mapDrawer.updateMap(prajurit);
                                parent.refreshTable();
                            }
                        }
                        else
                        {
                            parent.writeLog(LogLevel.Warn, "Update event is ignored when state is idle.");
                        }
                    }
                    else
                    {
                        parent.writeLog(LogLevel.Warn, "Event update from " + address + " with game id " + inPacket.getParameter("gameid") + " is ignored");
                    }
                }
                else if (type.Equals("ping"))
                {
                    // Reply with pong, and let the rest of parameters be the same.
                    inPacket.setParameter("type", "pong");
                    communication.send(address, inPacket);
                }
                else if (type.Equals("pantau/register"))
                {
                    if (inPacket.getParameter("gameid").Equals(gameId))
                    {
                        JSONPacket outPacket = new JSONPacket("pantau/confirm");
                        if (state == State.REGISTRATION && prajurits.Count == 0)
                        {
                            watchers.Add(address);
                            outPacket.setParameter("status", "ok");
                            outPacket.setParameter("gameid", gameId);
                            outPacket.setParameter("ammo", "" + initialAmmo);
                        }
                        else
                        {
                            outPacket.setParameter("status", "Tidak bisa pantau karena sudah ada prajurit yang bergabung atau latihan sudah dimulai.");
                        }
                        communication.send(address, outPacket, UDPCommunication.IN_PORT);
                        parent.writeLog(LogLevel.Info, address + " joined as watcher");
                    }
                    else
                    {
                        parent.writeLog(LogLevel.Warn, "Watch request from " + address + " is ignored, as the game id " + inPacket.getParameter("gameid") + " mismatched");
                    }
                }
                else if (type.Equals("pantau/state"))
                {
                    if (inPacket.getParameter("state").StartsWith("START"))
                    {
                        string[] tokens = inPacket.getParameter("state").Split('/');
                        for (int i = 0; i < tokens[1].Length; i++)
                        {
                            prajurits[i].group = "" + tokens[1][i];
                        }
                        startExercise();
                    }
                    else if (inPacket.getParameter("state").Equals("STOP"))
                    {
                        stopExercise(false);
                    }
                    else
                    {
                        parent.writeLog(LogLevel.Error, "Unknown state set: " + inPacket.getParameter("state"));
                    }
                }
                else
                {
                    parent.writeLog(LogLevel.Error, "Unknown type: " + type);
                }
            }
            catch (Exception e)
            {
                parent.writeLog(LogLevel.Error, "Unhandled exception: " + e);
            }
        }