Вопросы

Здравствуйте уважаемые пользователи форума.

Прошу Вашей помощи, на этом форуме уже выкладывали систему подарков: Кликабельна

Но она мне не подходит. Ее уже я пробовал.

 

Мне нужна система что-бы при подборе подарка к примеру 15 из 35. Что бы он записывал все подобранные значения в один переменную, а не в столько сколько подарков.

 

Пример: 

В Базе Данный есть переменная pPodarok хоронящий в себе не один подарок а несколько.

При этом нужно что бы при рестарте переменная pPodarok не сбрасывало значения. 

И при рестарте не приходилось собирать подарки по новой. 

 

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


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

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

  • 0

Вот с помощью этой штуки можно реализовать твою задумку https://pawno-rus.ru/topic/834-ispolzovanie-sscanf/

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


Ссылка на сообщение
  • 0
37 минут назад, DEST сказал:

Вот с помощью этой штуки можно реализовать твою задумку https://pawno-rus.ru/topic/834-ispolzovanie-sscanf/

Пока не очень понятно можете пример привести?

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


Ссылка на сообщение
  • 0
1 час назад, DEST сказал:

Вот с помощью этой штуки можно реализовать твою задумку https://pawno-rus.ru/topic/834-ispolzovanie-sscanf/

 

Вот что я смог сделать:

 

if(pickupid == podarok[1])
	{
		switch(random(2))
		{
			case 0:
			{
				GivePlayerMoney(playerid, 5000);
				pInfo[playerid][pCash] += 5000;
                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз %d рублей", pInfo[playerid][pCash]);
				SCM(playerid, COLOR_BLUE, stringer);
				sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[2]",pInfo[playerid][pPodarok]);
				pInfo[playerid][pPodarok]=1;
			}
			case 1:
			{
                GivePlayerMoney(playerid, 5000);
				pInfo[playerid][pCash] += 5000;
                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз %d рублей", pInfo[playerid][pCash]);
				SCM(playerid, COLOR_BLUE, stringer);
                sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[2]",pInfo[playerid][pPodarok]);
                pInfo[playerid][pPodarok]=1;
			}
		}
		pInfo[playerid][pPodarok]++;
		format(mysql_query_string, 200, "UPDATE "T_ACCOUNTS" SET podarok = '%d' WHERE name = '%s'", pInfo[playerid][pPodarok], pInfo[playerid][pName]);
		mysql_tquery(dbHandle, mysql_query_string, "", "");
	}

 

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


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

@Andrey_Akkerman в той теме приводятся примеры, все довольно-таки просто. 

В базе будут хранится данные: 0,0,0,0,0,0

                                                     1,2,3,4,5,6

Выделенный шрифт - порядковый номер подарка (в базе не отображается, приведен для наглядности). 

Обычный шрифт - значения подарка (в базе отображается именно в таком виде). 

Записывать соответственно так: 
 

new formatquery[?]; //где ? кол-во символов для запроса
format(formatquery, sizeof formatquery, "UPDATE table_name SET field_name = "%d, %d, %d, %d, %d" WHERE unique_field = unique_value", podarok[0], podarok[1], podarok[2] ... podarok[n]); 
mysql_tquery(dbHandle, formatquery, "", "");

Ну а как считывать пример в теме дан. 

Переменную нужно уже объявлять таким образом: 
 

new podarok[?]; // где вместо ? кол-во подарков

 

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


Ссылка на сообщение
  • 0
В 11.11.2017 в 00:15, DEST сказал:

@Andrey_Akkerman в той теме приводятся примеры, все довольно-таки просто. 

В базе будут хранится данные: 0,0,0,0,0,0

                                                     1,2,3,4,5,6

Выделенный шрифт - порядковый номер подарка (в базе не отображается, приведен для наглядности). 

Обычный шрифт - значения подарка (в базе отображается именно в таком виде). 

Записывать соответственно так: 
 


new formatquery[?]; //где ? кол-во символов для запроса
format(formatquery, sizeof formatquery, "UPDATE table_name SET field_name = "%d, %d, %d, %d, %d" WHERE unique_field = unique_value", podarok[0], podarok[1], podarok[2] ... podarok[n]); 
mysql_tquery(dbHandle, formatquery, "", "");

Ну а как считывать пример в теме дан. 

Переменную нужно уже объявлять таким образом: 
 


new podarok[?]; // где вместо ? кол-во подарков

 

 

Я сделал так, только он не сохраняет в БД, а он переводит в другое число.

На срине увидешь что там не то число которое  хотел.

Изображение 

Спойлер

    if(pickupid == podarok[0])
	{
 		if(podar[0][playerid] != 0) return SCM(playerid, COLOR_BLUE, "Вы забрали уже этот подарок!");
		{
			switch(random(3))
			{
				case 0:
				{
                    GivePlayerMoney(playerid, 5000000);
					pInfo[playerid][pCash] += 5000000;
	                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз %d рублей", GivePlayerMoney);
					SCM(playerid, COLOR_BLUE, stringer);
					sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);
				}
				case 1:
				{
                    GivePlayerMoney(playerid, 500000);
					pInfo[playerid][pCash] += 500000;
	                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз %d рублей", GivePlayerMoney);
					SCM(playerid, COLOR_BLUE, stringer);
					sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);
				}
				case 2:
				{
                    GivePlayerMoney(playerid, 50000);
					pInfo[playerid][pCash] += 50000;
	                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз %d рублей", GivePlayerMoney);
					SCM(playerid, COLOR_BLUE, stringer);
					sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);
				}
			}
		}
		podar[0][playerid] = 1;
		mysql_query_string[0] = EOS;
		format(mysql_query_string, sizeof(mysql_query_string), "UPDATE "T_ACCOUNTS"  SET podarok = '%d, %d, %d' WHERE id = %i", podarok[0], podarok[1], podarok[2], pInfo[playerid][pID]);
		mysql_tquery(dbHandle, mysql_query_string, "", "");
	}

 

 

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


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

@Andrey_Akkerman какая переменная у тебя отвечает за хранение информации о получении подарка?

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


Ссылка на сообщение
  • 0
11 минут назад, DEST сказал:

@Andrey_Akkerman какая переменная у тебя отвечает за хранение информации о получении подарка?

new podar[MAX_PLAYERS]

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


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

@Andrey_Akkerman ну вот значит при получении игроком подарка присваивать: 

podar[playerid][XX] = 1; 
//где вместо XX ид номер получаемого подарка (начиная с нуля)

И при выходе его из игры сохранять: 

new mysql_query[X]; 
mysql_format(connectionid, mysql_query, X, "UPDATE `table_accounts` SET `podarok` = '%d'", podar[playerid][0], podar[playerid][1], podar[playerid][2]); 
mysql_function_query(connectionid, mysql_query, false, "", "");

Ну и объявление переменной заменить:

new podar[MAX_PLAYERS][YY]; 
//где вместо YY кол-во подарков всего

 

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


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

Помоги ни как не могу разобратся, он в БД записывает подарки вот так: 1,1,1,1 и т.д.

Щас скину весь код по подаркам помоги.

 

Ко всем new

Спойлер

new podarok[3];
new podar[MAX_PLAYERS][3];

 

 

В enum аккаунта

Спойлер

pPodarok

 

 

в OnGameModeInit

Спойлер

	podarok[0] = CreateDynamicPickup(19054, 23, 2743.9409, -2491.8401, 21.6863, -1);
	podarok[1] = CreateDynamicPickup(19056, 23, 2741.4409, -2491.8401, 21.6863, -1);
	podarok[2] = CreateDynamicPickup(19054, 23, 2738.9409, -2491.8401, 21.6863, -1);

 

 

В OnPlayerConnect

Спойлер

pInfo[playerid][pPodarok] = 0;

 

 

В OnPlayerPickUpDynamicPickup

Для примера приведен 1 констант, остальные 2 точно такие же.

Спойлер

	if(pickupid == podarok[0])
	{
 		if(podar[0][playerid] >= 1) return SCM(playerid, COLOR_BLUE, "Вы забрали уже этот подарок!");
		{
			switch(random(3))
			{
				case 0:
				{
					switch(random(3))
					{
					    case 0:
						{
							pInfo[playerid][pExp] += 1;
			                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз +1 опыт");
							SCM(playerid, COLOR_BLUE, stringer);
							pInfo[playerid][pPodarok] = pInfo[playerid][pPodarok];
							sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);
						}
						case 1:
						{
							pInfo[playerid][pExp] += 10;
			                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз +10 опыта");
							SCM(playerid, COLOR_BLUE, stringer);
							pInfo[playerid][pPodarok] = pInfo[playerid][pPodarok];
							sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);
						}
						case 2:
						{
							pInfo[playerid][pExp] += 15;
			                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз +15 опыта");
							SCM(playerid, COLOR_BLUE, stringer);
							pInfo[playerid][pPodarok] = pInfo[playerid][pPodarok];
							sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);
						}
					}
				}
				case 1:
				{
                    GivePlayerMoney(playerid, 5000);
					pInfo[playerid][pCash] += 5000;
	                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз 5000 рублей");
					SCM(playerid, COLOR_BLUE, stringer);
					pInfo[playerid][pPodarok] = pInfo[playerid][pPodarok];
					sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);
				}
				case 2:
				{
					switch(random(3))
					{
					    case 0:
						{
							pInfo[playerid][pLevel] += 1;
			                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз +1 уровень");
							SCM(playerid, COLOR_BLUE, stringer);
							pInfo[playerid][pPodarok] = pInfo[playerid][pPodarok];
							sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);
						}
						case 1:
						{
							pInfo[playerid][pLevel] += 3;
			                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз +3 уровеня");
							SCM(playerid, COLOR_BLUE, stringer);
							pInfo[playerid][pPodarok] = pInfo[playerid][pPodarok];
							sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);
						}
						case 2:
						{
							pInfo[playerid][pLevel] += 5;
			                format(stringer, sizeof(stringer), "Вы подобрали подарок. Приз +5 уровеня");
							SCM(playerid, COLOR_BLUE, stringer);
							pInfo[playerid][pPodarok] = pInfo[playerid][pPodarok];
							sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);
						}
					}
				}
			}
		}
		podar[playerid][0] = 1;
		mysql_query_string[0] = EOS;
		format(mysql_query_string, sizeof(mysql_query_string), "UPDATE "T_ACCOUNTS"  SET podarok = '%i, %i, %i'", podar[playerid][0], podar[playerid][1], podar[playerid][2]);
		mysql_tquery(dbHandle, mysql_query_string, "", "");
	}

 

 

Вот весь код.

Он не сохраняет подарки после рестарта сервера.

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

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


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

@Andrey_Akkerman ты так и не разберешся, насоздавал 500 переменных, непонятно что хранящих. Сначала наведи порядок в своем коде, поудаляй вот эту хрень со сканфом, непонятно вообще что записывающую 

3 минуты назад, Andrey_Akkerman сказал:

sscanf(pInfo[playerid][pPodarok], "p<,>a<i>[3]",pInfo[playerid][pPodarok]);

Объясню в общем виде, под код сам подстроишь. 

В OnPlayerDisconnect добавь обнуление переменной для КАЖДОГО подарка: 

podarok[playerid][0] = 0; 
podarok[playerid][1] = 0; 
// и т.д. для всех

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

После, там,  где у тебя загрузка аккаунта добавь по примеру (скидывал тему в первом посте) загрузку этих данных, используя sscanf ( ИСПОЛЬЗОВАТЬ ЕГО НУЖНО ТОЛЬКО ЗДЕСЬ, А НЕ ПРИ ВЫДАЧЕ ). 

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


Ссылка на сообщение
  • 0
37 минут назад, DEST сказал:

@Andrey_Akkerman ты так и не разберешся, насоздавал 500 переменных, непонятно что хранящих. Сначала наведи порядок в своем коде, поудаляй вот эту хрень со сканфом, непонятно вообще что записывающую 

Объясню в общем виде, под код сам подстроишь. 

В OnPlayerDisconnect добавь обнуление переменной для КАЖДОГО подарка: 


podarok[playerid][0] = 0; 
podarok[playerid][1] = 0; 
// и т.д. для всех

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

После, там,  где у тебя загрузка аккаунта добавь по примеру (скидывал тему в первом посте) загрузку этих данных, используя sscanf ( ИСПОЛЬЗОВАТЬ ЕГО НУЖНО ТОЛЬКО ЗДЕСЬ, А НЕ ПРИ ВЫДАЧЕ ). 

То есть в OnPlayerDiscconect добавить сохранение подарков, а в загрузку аккаунтов что добавить?

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


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

@Andrey_Akkerman В OnPlayerDisconnect добавить обнуление. Там где все сохранения добавить сохранение, там где загрузка акка добавить загрузку по примеру, с использованием sscanf. Я же не знаю как у вас загрузка в моде идет. 

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


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

@steve Много,у нас не адекватов развелось..Пора банить уже.. 

 

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


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   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} };