Вопросы

DENIS.P.
Старожил

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

Спойлер

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
LilPokemon
Гуру форума

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

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


Ссылка на сообщение
  • 0
DENIS.P.
Старожил

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

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


Ссылка на сообщение
  • 0
LilPokemon
Гуру форума

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

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


Ссылка на сообщение
  • 0
DENIS.P.
Старожил

@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
LilPokemon
Гуру форума

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

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

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


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

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

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

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

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

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

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


Ссылка на сообщение
  • 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
LilPokemon
Гуру форума
Только что, 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
DENIS.P.
Старожил

@Покемон 

Спойлер

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 пользователей онлайн

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

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

    • Дебилойд
      От Дебилойд
      Здравствуйте!
      Мы ищем талантливого 3D-моделлера в команду нашего CRMP-проекта!
      Что нужно будет делать:
      Моделировать и адаптировать автомобили.
      Создавать и настраивать скины (модели персонажей).
      Большим плюсом будет:
      Умение создавать качественные и оптимизированные интерьеры.
      Если вы хотите стать частью нашей команды и развивать проект вместе с нами, пишите в ЛС. Ждем ваши портфолио!
    • LORDIKUS
      От LORDIKUS
      Уважаемые участники форума - всех приветствую, кто перешел в беседу моей темы обсуждения. В настоящее время у меня зарождается огромное желание и мысль создать собственный CR:MP проект, но столкнулся с единственной проблемой - с отсутствием команды людей, у которых будет искреннее желание ежедневно вкладывать свой труд на разработку проекта. Особого опыта в скриптинге, маппинге, дизайне или в моделировании у меня не имеется, поэтому такой критерий как опыт в определенной сфере для желающих вступить в команду я не рассматриваю. Так как проект не открыт и находится на начальной стадии создания, мое сотрудничество выстраивается на некоммерческой основе (без выплаты за проделанную работу и труд), однако я не собираюсь отрицать высокую ценность вложенного командой труд — труд, особенно на первой стадии разработки я рассматриваю превыше всего. После открытия проекта в зависимости от коммерции и чистой прибыли каждый участник будет получать настоящую выплату, однако это также может убить еще значительное время. Мне нужна команда, которая проявит искренний интерес в создании общего между командой CR:MP проекта, пожертвует свое время, а также вложит собственный труд благодаря заработанным навыкам. Если вас заинтересовала данная тема обсуждения, пожалуйста, свяжитесь со мной по любым возможным и удобным для вас контактам связи ниже. Спасибо всем, кто зашел в мою беседу!

      🔗 Спец. Связь:
      — DISCORD: https://discord.com/users/1452715348196589691 (перейти по ссылке и добавить в друзья) ИЛИ _shin833_ (ввести никнейм и отправить запрос дружбы)
      — VK: https://vk.com/shin833
      — TG: https://t.me/s_hin833
    • Korochansky
      От Korochansky
      Настало время объявить о скором выпуске первого релиза среды разработки под названием Spawn.

      В настоящее время программа находится на заключительных этапах доработки кода и локализации интерфейса.
      Таким образом, в течение следующей недели будет выпущена быстрая и современная среда разработки, обладающая следующими возможностями (о которых я расскажу сейчас, а о других — позже):
       
      Полнофункциональный локальный Git: 
      Индексирование, фиксации, индикаторы состояния и мягкий/жесткий сброс до любой точки сохранения одним щелчком мыши. Разрабатывайте свой игровой сервер, не боясь его сломать.
      Новички могут рассматривать это как историю кодовой базы вашего сервера (что и есть на самом деле).
       
      Чистый UTF-8 (без BOM): 
      Полный отказ от устаревшей кодировки Windows-1251 (CP1251) для абсолютной стабильности и идеальной совместимости с Git.
      Реализация поддержки CP1251 привела бы к нестабильному поведению программы и ухудшила бы пользовательский опыт.
       
      История изменений строк: Редактор выделяет измененные строки в реальном времени в полях рядом с номерами строк. Это позволяет мгновенно видеть границы изменений, внесенных с момента открытия файла.
       
      Сопоставление и выделение фигурных скобок: мгновенное выделение открывающих и закрывающих фигурных скобок для быстрой навигации по структуре кода и защиты от ошибок компиляции.
       
      Интеграция с SAMPCTL: готовая к использованию автоматизация процессов. Сборка, запуск сервера и менеджер зависимостей (управление библиотеками и плагинами) работают напрямую из интерфейса редактора.
       
      И многое другое...
       
      И самое главное: проект будет с открытым исходным кодом под лицензией GPLv3!
      Следите за новостями о выпуске в репозитории: https://github.com/daniilkorochansky/spawn
    • KodBi
      От KodBi
      шапка
      по одиночке работают
      нужны оба