Вопросы

Добрый день, у меня такая проблема, когда покупаю бизнес, все хорошо он мой и на бизнесе три де текстом пишет владельца, но как только я сделаю рестарт, то бизнес пропадает, его уже может купить другой игрок, но если буду покупать его я, то мне пишет, что я им владею. 

Спойлер

if(strcmp(cmd,"/buyatm",true) == 0)
	{
		if(PlayerInfo[playerid][pAtm] != 255) return SendClientMessage(playerid, COLOR_WHITE, "У вас уже есть банкомат.");
		for(new b = 0; b < sizeof(Atm); b++)
		{
			if(PlayerToPoint(5.0, playerid, Atm[b][atmX], Atm[b][atmY], Atm[b][atmZ]) && Atm[b][atmOwned] == 0)
			{
				if(PlayerInfo[playerid][pCash] < Atm[b][atmCena]) return SendClientMessage(playerid, COLOR_WHITE, "На Вашем счету нет столько денег!");
				if(PlayerInfo[playerid][pLevel] < Atm[b][atmLevel])
				{
					SFCM(playerid, -1, "У вас недостаточный уровен, нужен: %i", Atm[b][atmLevel]);
					return 1;
				}
				PlayerInfo[playerid][pAtm] = b;
				Atm[b][atmOwned] = 1; Atm[b][atmMoney] = 100; Atm[b][atmLock] = 0;
				strmid(Atm[b][atmOwner], NamePlayer[playerid], 0, strlen(NamePlayer[playerid]), 255);
				GivePlayerMoney(playerid, -Atm[b][atmCena]), PlayerInfo[playerid][pCash] -= Atm[b][atmCena];
				SendClientMessage(playerid, COLOR_LIGHTGREEN, "Поздравляем с успешной покупкой.");
				SendClientMessage(playerid, COLOR_GREEN, "Каждый час с вашего банкомата будет взыматься плата за электричество.");
				SendClientMessage(playerid, COLOR_WHITE, "(( Помощь по банкомата: /atmenu ))");
				UpdateAtm(b);
				mysql_function(MySQLGo,128,"UPDATE `accounts` SET `pAtm` = '%i' WHERE `id` = '%d' LIMIT 1",false,"","", PlayerInfo[playerid][pAtm],PlayerInfo[playerid][pID]);
			}
		}
		return true;
	}
Спойлер

// Система банкоматов
stock UpdateAtm(idx)
{
        glob_str = "";
        format(glob_str, sizeof(glob_str), "UPDATE `atm` SET `owner` = '%s',`cena` = '%i',`money` = '%i',`lvl` = '%i',`lock` = '%i' WHERE `ID` = '%i'", Atm[idx][atmOwner],Atm[idx][atmCena],Atm[idx]
[atmMoney],Atm[idx][atmLevel],Atm[idx][atmLock]
,Atm[idx][atmID]);
        mysql_tquery(MySQLGo, glob_str);
        glob_str = "";
        format(glob_str, sizeof(glob_str), "UPDATE `atm` SET `x` = '%f',`y` = '%f',`z` = '%f',`owned` = '%i' WHERE `ID` = '%i'", Atm[idx][atmX],Atm[idx][atmY],Atm[idx][
atmZ],Atm[idx][atmOwned],Atm[idx][atmID]);
        mysql_tquery(MySQLGo, glob_str);
        glob_str = "";
        if(mysql_errno()) printf("Ошибка сохранения банкомата: [%d]", Atm[idx][atmID]);
        else printf("Успешно сохранение банкомата: [%d]", Atm[idx][atmID]);

        //
        DestroyDynamic3DTextLabel(Atm[idx][atmText]);
        if(!strcmp(Atm[idx][atmOwner],"None",true))
        {
                format(glob_str, sizeof(glob_str), "{008cf0}Банкомат №{FFFFFF}%i {008cf0}продается!\n\n{008cf0}Стоимость: {FFFFFF}%d рублей\n{008cf0}Уровень: {FFFFFF}%d", idx, Atm[idx][atmCena], Atm[idx][atmLevel]);
                Atm[idx][atmText] = CreateDynamic3DTextLabel(glob_str,-1, Atm[idx][atmX],Atm[idx][atmY],Atm[idx][
atmZ], 10.0);
                glob_str = "";
        }
        else
        {
                format(glob_str, sizeof(glob_str), "{008cf0}Банкомат №{FFFFFF}%i\n\n{008cf0}Владелец: {FFFFFF}%s", idx, Atm[idx][atmOwner]);
                Atm[idx][atmText] = CreateDynamic3DTextLabel(glob_str,-1, Atm[idx][atmX],Atm[idx][atmY],Atm[idx][
atmZ], 10.0);
                glob_str = "";
        }
        return true;
} 

 

Поделиться сообщением


Ссылка на сообщение

13 ответов на этот вопрос

  • 0

Проблема ришина через вк,  проблема было в этом cache_get_field_content(idx, "owner", Atm[idx][atmOwner], MySQLGo, strlen(Atm[idx][atmOwner])); в чем именно strlen(Atm[idx][atmOwner]) он не давал длину ника по этому это заменили на 24 и все заработало! 

Поделиться сообщением


Ссылка на сообщение
  • 0

@DENIS.P. в базе данных информация о купленном бизе есть? 

Поделиться сообщением


Ссылка на сообщение
  • 0

@DEST да есть, и когда его купишь в owner пишется нормальный покупатель, после рестарта он от туда слетает. и вот получается бизнес не его. 

Поделиться сообщением


Ссылка на сообщение
  • 0

@DENIS.P. код рестарта скидывай

Поделиться сообщением


Ссылка на сообщение
  • 0

Скорее всего у тебя нет загрузки бизнесов, посмотри может и не загружаешь их. Или же ты его не сохраняешь, когда делаешь рестарт если не добавить сохранения данных то они не сохраняться просто на просто.

Поделиться сообщением


Ссылка на сообщение
  • 0

@DEST @Покемон

Спойлер

//==============================================================================
    if(strcmp(cmd, "/gmx", true) == 0)
    {
        if(IsPlayerConnected(playerid))
        {
            if(PlayerInfo[playerid][pAdmin] < 10) return SendClientMessage(playerid, COLOR_GRAD1, "Âû íå àäìèíèñòðàòîð.");
            {
                GetPlayerName(playerid, sendername, sizeof(sendername));
                format(string,sizeof(string),"AdmCmd: %s ïåðåçàïóñòèë ãåéì-ìîä ñåðâåðà.",sendername);
                SendClientMessageToAll(COLOR_RED,string);
                GameModeExit();
            }
        }
        return 1;
    }

Спойлер

public OnGameModeExit()
{
   //êàìåðà ïîëåòà
       for(new x; x<MAX_PLAYERS; x++)
    {
        if(noclipdata[x][cameramode] == CAMERA_MODE_FLY) CancelFlyMode(x);
    }
   //
    for(new i; i < GetMaxPlayers(); i++)
    {
        SaveAccounts();
        SaveAcc(i);
        SaveVehicle(i);
        UpdateGarage(i);
        updatekvar(i);
        UpdateAtm(i);
        OnPropUpdate(i);
        UpdateLarek(i);
        SavePlayer(i);
        SaveHouse(i);
        PlayerTextDrawDestroy(i,MoneyCounter);
    }
    KillTimer(BabloTimer);
       printf("OnGameModeExit äîñòèã êîíöà");
    return 1;
}

Тут вот после рестарта идет сохранение всего. 

Поделиться сообщением


Ссылка на сообщение
  • 0

Скинь сток сохранения бизнесов 

Отредактировано пользователем Покемон

Поделиться сообщением


Ссылка на сообщение
  • 0

@Покемон больше нету.

ничего вот обновление только. 

Поделиться сообщением


Ссылка на сообщение
  • 0
3 минуты назад, DENIS.P. сказал:

@Покемон больше нету.

ничего вот обновление только. 

Значит у тебя нет сохранения бизнесов, так как ты тогда владельца сохранять собираешь ?) сток же должен быть чтобы новую информацию сохранять о владельцы к примеру. Если же нету у тебя не чего значит в этом и проблема. Загрузка у тебя есть ? 

Если есть то кидай сюда, и скажи какая у тебя база данных mysql.

Отредактировано пользователем Покемон

Поделиться сообщением


Ссылка на сообщение
  • 0

@Покемон 

Спойлер

// Загрузка с MYSQL
    mysql_function_query(MySQLGo, "SELECT * FROM `kazna`", true, "LoadBank", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `vehicles`", true, "LoadVehicles", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `pod`", true, "LoadPod", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `houses`", true, "LoadHouses", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `flat`", true, "LoadFlat", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `biz_acc`", true, "LoadAcc", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `garage`", true, "LoadGarage", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `fuels`", true, "LoadFuels", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `lareks`", true, "LoadLareks", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `casino`", true, "LoadCasino", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `atm`", true, "LoadAtm", "");

это? 

Поделиться сообщением


Ссылка на сообщение
  • 0
Только что, DENIS.P. сказал:

@Покемон 

  код (закрыть спойлер)

// Загрузка с MYSQL
    mysql_function_query(MySQLGo, "SELECT * FROM `kazna`", true, "LoadBank", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `vehicles`", true, "LoadVehicles", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `pod`", true, "LoadPod", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `houses`", true, "LoadHouses", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `flat`", true, "LoadFlat", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `biz_acc`", true, "LoadAcc", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `garage`", true, "LoadGarage", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `fuels`", true, "LoadFuels", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `lareks`", true, "LoadLareks", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `casino`", true, "LoadCasino", "");
    mysql_function_query(MySQLGo, "SELECT * FROM `atm`", true, "LoadAtm", "");

это? 

Паблик самой загрузки бизнеса. 

Поделиться сообщением


Ссылка на сообщение
  • 0

@Покемон 

Спойлер

publics: LoadAtm()
{
    new rows, fields, str[200];
    cache_get_data(rows, fields);
    if(rows)
    {
        for(new idx = 0; idx < cache_num_rows(); idx++)
        {
            // content
            cache_get_field_content(idx, "owner", Atm[idx][atmOwner], MySQLGo, strlen(Atm[idx][atmOwner]));

            // int
            Atm[idx][atmID] = cache_get_field_content_int(idx, "ID");
            Atm[idx][atmCena] = cache_get_field_content_int(idx, "cena");
            Atm[idx][atmLevel] = cache_get_field_content_int(idx, "lvl");
            Atm[idx][atmMoney] = cache_get_field_content_int(idx, "money");
            Atm[idx][atmOwned] = cache_get_field_content_int(idx, "owned");
            Atm[idx][atmLock] = cache_get_field_content_int(idx, "lock");

            // float
            Atm[idx][atmX] = cache_get_field_content_float(idx, "x");
            Atm[idx][atmY] = cache_get_field_content_float(idx, "y");
            Atm[idx][atmZ] = cache_get_field_content_float(idx, "z");
            ALLATM++;

            //
            if(!strcmp(Atm[idx][atmOwner],"None",true))
            {
                format(str, 200, "{008cf0}Банкомат №%i продается!\n\n{008cf0}Стоимость: {ffffff}%d рублей\n{008cf0}Уровень: {ffffff}%d", idx, Atm[idx][atmCena], Atm[idx][atmLevel]);
                Atm[idx][atmText] = CreateDynamic3DTextLabel(str,-1, Atm[idx][atmX],Atm[idx][atmY],Atm[idx][atmZ], 10.0);
            }
            else
            {
                format(str, 200, "{008cf0}Банкомат №%i\n\n{008cf0}Владелец: {ffffff}%s", idx, Atm[idx][atmOwner]);
                Atm[idx][atmText] = CreateDynamic3DTextLabel(str,-1, Atm[idx][atmX],Atm[idx][atmY],Atm[idx][atmZ], 10.0);
            }
            Atm[idx][atmMapIc] = CreateDynamicMapIcon(Atm[idx][atmX],Atm[idx][atmY],Atm[idx][atmZ],52,0);
        }
        printf("[Загрузка MYSQL]: Банкоматы успешно загружены. Всего: %d",ALLATM);
    }
}

 

Отредактировано пользователем DENIS.P.

Поделиться сообщением


Ссылка на сообщение
  • 0

Извини пожалуйста, не увидел сохранения. 

Поделиться сообщением


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • Mister Odin
      От Mister Odin
       
      new
       g_teleport_list[39][E_TELEPORT_LIST] = {  {"Спавн пгт.Батырево", 1802.3612, 2508.4824, 15.8887},  {"Спавн г.Арзамас", -113.5887, 977.7222, 12.0346},     {"Спавн г.Южный", 2744.2770, -2446.7246, 21.8988},     {"Центральный банк", 1852.020385,2040.791381,15.892713},  {"Рублёвка", -837.7783, 888.6161, 12.7232},  {"Казино", 1332.4252, 2358.7014, 17.6641},  {"Битва за контейнеры", 614.5167, 1722.3566, 12.0709},  {"Автосалон низкого класса", 2493.9616, -722.9544, 12.3315},  {"Автосалон среднего класса", 1407.7449, 455.4801, 13.1630},  {"Автосалон высокого класса", -14.0637, 2614.5664, 10.9892},   {"Мотосалон Harley Davidson", 785.720153, 750.465087, 12.000024},  {"Автошкола", 1909.174438,2227.679687,15.708162},  {"Военкомат", 1916.778564,2302.411376,15.574637},  {"Правительство области", -139.140975,593.789611,12.145712},  {"Отдел полиции №1 (ГИБДД)", 1906.805786,-2234.382812,11.257631},  {"Отдел полиции №2 (УМВД)", 2581.309326,-2416.139892,21.960090},  {"Отдел ФСБ", 1823.904663,2095.636718,15.848405},  {"Городская больница г.Арзамас", -285.797210,581.851562,12.120290},   {"СМИ", -317.708038,821.221679,13.051450},  {"Воинская часть", 1703.197265,1678.025878,15.279437},  {"Арзамасская ОПГ", 438.705322,1046.505126,12.002637},  {"Батыревская ОПГ", 1941.203857,2161.006591,15.705187},  {"Лыткаринская ОПГ", -2346.002441,75.257041,21.002962},  {"Шахта", 2381.5727, 1726.4451, -2.1506},  {"Завод", -1062.6697, 2204.1894, 38.0964},  {"Инкосация", 1864.1374, 2011.7136, 15.8546},  {"Транспортная Компания", 2362.1115, 1972.5627, 15.5530},  {"База механиков", 1840.918090,-118.025146,15.695312},  {"Курьерская служба доставки", 2764.509765,-2396.882568,21.890625},  {"Аренда автобуса(Южный)", 2771.041992,-2454.780761,21.845964},  {"Аренда автобуса(Арзамас)", -127.487670,943.652648,12.142824},   {"Аренда автобуса(Батырево)", 1798.986328,2529.591552,15.664262},  {"Гоночная трасса", -1568.7784, 1611.8305, 36.3971},  {"Дом на горе", -789.5397, -456.7479, 741.1422},  {"СТО и тюнинг-ателье", 1856.1375, -122.3266, 15.6888},  {"Аренда транспорта пгт.Батырево", 1763.641723,2255.673339,15.865348},  {"Аренда транспорта г.Арзамас", -36.923530,1360.673583,12.002090},  {"Аренда транспорта г.Южный", 1966.599975,-2603.943603,10.820312},  {"Тайный интерьер в Лыткарино", -2424.5818, 2846.3291, 40.7908} };