예제 #1
0
        public void Trade()
        {
#if DEBUG
            Log("Trade!");
#endif
            int sleep = 0;
            while (true)
            {
                try
                {
                    sleep = 8 + new Random().Next(-5, 5);

                    if (trading) // Если торгуем
                    {
                        Log("Step with \"" + listBox_ResList.SelectedItem.ToString() + "\"");
                        // Получаем ID товара из списка
                        int resID = GetID(listBox_ResList.SelectedItem.ToString());

                        int targetID = -1;
                        //List<int> villageIDs = GameEngine.Instance.World.getListOfUserVillages(); // Получаем список наших деревень

                        for (int i = 0; i < listBox_ActiveVillages.Items.Count; i++)
                        //foreach (int villageID in villageIDs) // Перебираем их
                        {
                            if (!listBox_ActiveVillages.GetSelected(i))
                            {
                                continue;
                            }
                            int villageID = GetID(listBox_ActiveVillages.Items[i].ToString());

                            // Если деревня прогружена (открывалась ее карта в текущей сессии хоть раз)
                            if (GameEngine.Instance.getVillage(villageID) != null)
                            {
                                // Получаем базовую информацию о нашей деревни
                                WorldMap.VillageData village = GameEngine.Instance.World.getVillageData(villageID);
                                VillageMap           map     = GameEngine.Instance.getVillage(villageID); // Получаем полную информацию
                                int merchantsCount           = map.calcTotalTradersAtHome();              // Кол-во торговцев в ней
                                if (merchantsCount == 0)
                                {
                                    continue;
                                }

                                int resAmount = (int)map.getResourceLevel(resID);                                                 // Кол-во ресурса на складе
                                Log("At village " + villageID + " (" + village.villageName + ") " + merchantsCount + " traders"); // Дебаг

                                int sendWithOne = int.Parse(textBox_ResCount.Text);                                               // Кол-во ресурса на торговца
                                int maxAmount   = merchantsCount * sendWithOne;                                                   // Кол-во ресурсов отправим
                                if (resAmount < maxAmount)                                                                        // Если торговцы могут увезти больше чем есть
                                {
                                    merchantsCount = (int)(resAmount / sendWithOne);                                              // Считаем сколько смогут увезти реально
                                }
                                if (merchantsCount > 0)                                                                           // Если трейдеры дома есть
                                {
                                    if (radioButton1.Checked)                                                                     // Parish
                                    {
                                        targetID = GameEngine.Instance.World.getRegionCapitalVillage(village.regionID);
                                    }
                                    else if (radioButton2.Checked) // Target
                                    {
                                        targetID = int.Parse(textBox_TradeTargetID.Text);
                                    }
                                    else if (radioButton3.Checked) // Resell
                                    {
                                        InterfaceMgr.Instance.selectStockExchange(-1);
                                        GameEngine.Instance.SkipVillageTab();
                                        InterfaceMgr.Instance.getMainTabBar().changeTab(1);
                                        InterfaceMgr.Instance.setVillageTabSubMode(3);
                                        InterfaceMgr.Instance.resetVillageReportPanelData();
                                        InterfaceMgr.Instance.selectStockExchange(int.Parse(listBox_ParishList.Items[0].ToString()));
                                    }


                                    // if target - player
                                    // GameEngine.Instance.getVillage(id).sendResources()
                                    // Вызываем высокоуровневую функцию торговли с рядом каллбеков
                                    GameEngine.Instance.getVillage(villageID).stockExchangeTrade(targetID, resID, merchantsCount * sendWithOne, false);
                                    AllVillagesPanel.travellersChanged(); // Подтверждаем изменения (ушли трейдеры) в GUI-клиента
                                }
                            }
                        }

                        Log("Again in " + sleep + " seconds - " + DateTime.Now.AddSeconds(sleep).ToString("HH:mm:ss"));
                        Console.WriteLine();
                    }
                }
                catch (Exception ex)
                {
                    WriteLog(ex);
                }

                Thread.Sleep(sleep * 1000); // Спим, чтобы не спамить. Так меньше палева.
            }
        }
예제 #2
0
        public void Trade()
        {
            Log("Торговый поток создан!");

            int Sleep = 0;

            while (true)
            {
                try
                {
                    Sleep = 60 + new Random().Next(-5, 60);

                    if (IsTrading) // Если торгуем
                    {
                        Log("Заход с \"" + listBox_ResList.SelectedItem.ToString() + "\"");
                        // Получаем ID товара из списка
                        int        ResID      = GetItemID(listBox_ResList.SelectedItem.ToString());
                        int        TargetID   = int.Parse(textBox_TradeTargetID.Text);             // Получаем ID деревни-цели
                        List <int> VillageIDs = GameEngine.Instance.World.getListOfUserVillages(); // Получаем список наших деревень

                        foreach (int VillageID in VillageIDs)                                      // Перебираем их
                        {
                            // Если деревня прогружена (открывалась ее карта в текущей сессии хоть раз)
                            if (GameEngine.Instance.getVillage(VillageID) != null)
                            {
                                // Получаем базовую информацию о нашей деревни
                                WorldMap.VillageData Village = GameEngine.Instance.World.getVillageData(VillageID);
                                VillageMap           Map     = GameEngine.Instance.getVillage(VillageID); // Получаем полную информацию
                                int ResAmount      = (int)Map.getResourceLevel(ResID);                    // Кол-во ресурса на складе
                                int MerchantsCount = Map.calcTotalTradersAtHome();                        // Кол-во торговцев в ней
                                Log("В деревне " + VillageID + " есть " + MerchantsCount + " торговцев"); // Дебаг

                                int SendWithOne = int.Parse(textBox_ResCount.Text);                       // Кол-во ресурса на торговца
                                int MaxAmount   = MerchantsCount * SendWithOne;                           // Кол-во ресурсов отправим
                                if (ResAmount < MaxAmount)                                                // Если торговцы могут увезти больше чем есть
                                {
                                    MerchantsCount = (int)(ResAmount / SendWithOne);                      // Считаем сколько смогут увезти реально
                                }
                                if (MerchantsCount > 0)                                                   // Если трейдеры дома есть
                                {
                                    TargetID = (checkBox_Parish.Checked ?
                                                GameEngine.Instance.World.getRegionCapitalVillage(Village.regionID) :
                                                int.Parse(textBox_TradeTargetID.Text));
                                    //textBox_TradeTargetID.Text = TargetID.ToString();

                                    // Вызываем высокоуровневую функцию торговли с рядом каллбеков
                                    GameEngine.Instance.getVillage(VillageID).stockExchangeTrade(TargetID, ResID, MerchantsCount * SendWithOne, false);
                                    AllVillagesPanel.travellersChanged(); // Подтверждаем изменения (ушли трейдеры) в GUI-клиента
                                }
                            }
                        }

                        Log("Повтор цикла торговли через " + Sleep + " секунд(ы) в " + DateTime.Now.AddSeconds(Sleep).ToString("HH:mm:ss"));
                        Console.WriteLine();
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine("\n======| EX INFO |======");
                    Console.WriteLine(ex);
                    Console.WriteLine("======| ======= |======\n");
                }

                Thread.Sleep(Sleep * 1000); // Спим, чтобы не спамить. Так меньше палева.
            }
        }