Добро пожаловать на Pro Pawn - Портал о PAWN-скриптинге.
Показано с 1 по 5 из 5
  1. #1
    Аватар для Dimon_Fanat
    Пользователь

    Статус
    Оффлайн
    Регистрация
    01.06.2014
    Сообщений
    131
    Репутация:
    0 ±

    Правильно ли оформлен цикл загрузки бизнесов?

    Добрый день, скажите правильно ли делаю for?

    PHP код:
    enum bInfo
    {
        
    bID,
        
    bName[32],
        
    bType,
    Float:bEnterX,
    Float:bEnterY,
    Float:bEnterZ,
    Float:bExitX,
    Float:bExitY,
    Float:bExitZ,
        
    bInterior,
    }
    new 
    BizInfo[MAX_BUSINESS][bInfo]; 
    PHP код:
            for(new 0sizeof(BizInfo); i++)
            {
                if(
    IsPlayerInRangeOfPoint(playerid,0.8,BizInfo[i][bEnterX],BizInfo[i][bEnterY],BizInfo[i][bEnterZ]))
                {
                    
    SetPlayerPos(playerid,BizInfo[i][bExitX],BizInfo[i][bExitY],BizInfo[i][bExitZ]);
                    
    SetPlayerInterior(playerid,BizInfo[i][bInterior]);
                    
    SetPlayerVirtualWorld(playerid,BizInfo[i][bID]);
                }
            } 

    PHP код:
    publics LoadBusiness()
    {
        new 
    rows;
        
    cache_get_row_count(rows);
        for(new 
    0rowsi++)
        {
            
    cache_get_value_name_int(i,"ID",BizInfo[i][bID]);
            
    cache_get_value_name(i,"NameBiz",BizInfo[i][bName],32);
            
    cache_get_value_name_int(i,"Type",BizInfo[i][bType]);
            
    cache_get_value_name_float(i,"EnterX",BizInfo[i][bEnterX]);
            
    cache_get_value_name_float(i,"EnterY",BizInfo[i][bEnterY]);
            
    cache_get_value_name_float(i,"EnterZ",BizInfo[i][bEnterZ]);
            
    cache_get_value_name_float(i,"ExitX",BizInfo[i][bExitX]);
            
    cache_get_value_name_float(i,"ExitY",BizInfo[i][bExitY]);
            
    cache_get_value_name_float(i,"ExitZ",BizInfo[i][bExitZ]);
            
    cache_get_value_name_int(i,"Interior",BizInfo[i][bInterior]);
            
            
    CreateDynamicMapIcon(BizInfo[i][bEnterX],BizInfo[i][bEnterY],BizInfo[i][bEnterZ],BizInfo[i][bType],0xFFFFFFAA,0,-1,-1,400.0);
            
    CreateDynamicCP(BizInfo[i][bEnterX],BizInfo[i][bEnterY],BizInfo[i][bEnterZ],1.0,-1,-1,-1,3.0);
        }
        
    printf("Загружено [%i] бизнесов.",rows);


  2. #2
    Аватар для DeimoS
    Модератор?

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    Да. Только нужно ещё либо в запрос добавить
    1. "... LIMIT %d", ..., sizeof(BizInfo));

    Либо в LoadBusiness
    1. publics LoadBusiness()
    2. {
    3. new rows;
    4. cache_get_row_count(rows);
    5.  
    6. if(rows == 0)
    7. return 0;
    8. if(rows >= sizeof(BizInfo))
    9. rows = sizeof(BizInfo);
    10.  
    11. for(new i = 0; i < rows; i++)

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

    UPD: Вот так можно сделать ещё

    1. publics LoadBusiness()
    2. {
    3. new rows;
    4. cache_get_row_count(rows);
    5. if(!rows)
    6. {
    7. print("Загружено [0] бизнесов. Таблица с бизнесами пуста!");
    8. return 0;
    9. }
    10. else if(rows >= sizeof(BizInfo))
    11. {
    12. printf("Внимание: в таблице с бизнесами слишком много строк. Увеличте массив BizInfo на %d, дабы исправить ошибку [%d|%d]", rows-sizeof(BizInfo), rows, sizeof(BizInfo));
    13. rows = sizeof(BizInfo);
    14. }
    15. new Float:x,
    16. Float:y,
    17. Float:z;
    18. for(new i = 0; i < rows; i++)
    19. {
    20. cache_get_value_name_int(i,"ID",BizInfo[i][bID]);
    21. cache_get_value_name(i,"NameBiz",BizInfo[i][bName],32);
    22. cache_get_value_name_int(i,"Type",BizInfo[i][bType]);
    23. cache_get_value_name_float(i,"EnterX", x);
    24. cache_get_value_name_float(i,"EnterY", y);
    25. cache_get_value_name_float(i,"EnterZ", z);
    26. cache_get_value_name_float(i,"ExitX",BizInfo[i][bExitX]);
    27. cache_get_value_name_float(i,"ExitY",BizInfo[i][bExitY]);
    28. cache_get_value_name_float(i,"ExitZ",BizInfo[i][bExitZ]);
    29. cache_get_value_name_int(i,"Interior",BizInfo[i][bInterior]);
    30.  
    31. BizInfo[i][bEnterX] = x;
    32. BizInfo[i][bEnterY] = y;
    33. BizInfo[i][bEnterZ] = z;
    34.  
    35. CreateDynamicMapIcon(x, y, z, BizInfo[i][bType],0xFFFFFFAA,0,-1,-1,400.0);
    36. CreateDynamicCP(x, y, z, 1.0, -1, -1, -1, 3.0);
    37. }
    38. printf("Загружено [%i] бизнесов.",rows);
    39. }
    Последний раз редактировалось DeimoS; 05.06.2018 в 20:31.
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

    Широко известно, что идеи стоят 0.8333 цента каждая (исходя из рыночной цены 10 центов за дюжину).
    Великих идей полно, на них нет спроса.
    Воплощение идеи в законченную игру требует долгой работы,
    таланта, терпения и креативности, не говоря уж о затратах денег, времени и ресурсов.
    Предложить идею просто, воплотить – вот в чём проблема

    Steve Pavlina

  3. #3
    Аватар для Dimon_Fanat
    Пользователь

    Статус
    Оффлайн
    Регистрация
    01.06.2014
    Сообщений
    131
    Репутация:
    0 ±
    Цитата Сообщение от DeimoS Посмотреть сообщение
    Да. Только нужно ещё либо в запрос добавить
    1. "... LIMIT %d", ..., sizeof(BizInfo));

    Либо в LoadBusiness
    1. publics LoadBusiness()
    2. {
    3. new rows;
    4. cache_get_row_count(rows);
    5.  
    6. if(rows == 0)
    7. return 0;
    8. if(rows >= sizeof(BizInfo))
    9. rows = sizeof(BizInfo);
    10.  
    11. for(new i = 0; i < rows; i++)

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

    UPD: Вот так можно сделать ещё

    1. publics LoadBusiness()
    2. {
    3. new rows;
    4. cache_get_row_count(rows);
    5. if(!rows)
    6. {
    7. print("Загружено [0] бизнесов. Таблица с бизнесами пуста!");
    8. return 0;
    9. }
    10. else if(rows >= sizeof(BizInfo))
    11. {
    12. printf("Внимание: в таблице с бизнесами слишком много строк. Увеличте массив BizInfo на %d, дабы исправить ошибку [%d|%d]", rows-sizeof(BizInfo), rows, sizeof(BizInfo));
    13. rows = sizeof(BizInfo);
    14. }
    15. new Float:x,
    16. Float:y,
    17. Float:z;
    18. for(new i = 0; i < rows; i++)
    19. {
    20. cache_get_value_name_int(i,"ID",BizInfo[i][bID]);
    21. cache_get_value_name(i,"NameBiz",BizInfo[i][bName],32);
    22. cache_get_value_name_int(i,"Type",BizInfo[i][bType]);
    23. cache_get_value_name_float(i,"EnterX", x);
    24. cache_get_value_name_float(i,"EnterY", y);
    25. cache_get_value_name_float(i,"EnterZ", z);
    26. cache_get_value_name_float(i,"ExitX",BizInfo[i][bExitX]);
    27. cache_get_value_name_float(i,"ExitY",BizInfo[i][bExitY]);
    28. cache_get_value_name_float(i,"ExitZ",BizInfo[i][bExitZ]);
    29. cache_get_value_name_int(i,"Interior",BizInfo[i][bInterior]);
    30.  
    31. BizInfo[i][bEnterX] = x;
    32. BizInfo[i][bEnterY] = y;
    33. BizInfo[i][bEnterZ] = z;
    34.  
    35. CreateDynamicMapIcon(x, y, z, BizInfo[i][bType],0xFFFFFFAA,0,-1,-1,400.0);
    36. CreateDynamicCP(x, y, z, 1.0, -1, -1, -1, 3.0);
    37. }
    38. printf("Загружено [%i] бизнесов.",rows);
    39. }
    Понял, спасибо!
    А еще такой вопрос, допустим у меня бизнес в базе данных начинается с 1, 0 бизнеса нет, но когда я ввожу команду /goto и тп к бизнесу 1, меня тп к бизнесу №2, а если введу №0 то тп к бизнесу 1.

    PHP код:
    CMD:gotobiz(playerid,params[])
    {
        if(
    sscanf(params,"d",params[0]))return SendClientMessage(playerid,0x00BFFFAA,"[КОМАНДЫ] {FFFFFF}/gotobiz [id бизнеса].");
        if(
    params[0] < || params[0] >= sizeof(BizInfo))return SendClientMessage(playerid,0x00BFFFAA"Неправильный номер бизнеса");
        
    SetPlayerPos(playerid,BizInfo[params[0]][bEnterX],BizInfo[params[0]][bEnterY],BizInfo[params[0]][bEnterZ]);
        
    SetPlayerVirtualWorld(playerid,0);
        
    SetPlayerInterior(playerid,0);
        return 
    1;


  4. #4
    Аватар для Geebrox
    Пользователь

    Статус
    Оффлайн
    Регистрация
    24.08.2015
    Адрес
    Ташкент
    Сообщений
    375
    Репутация:
    97 ±
    Можно так:

    1. publics LoadBusiness()
    2. {
    3. new rows;
    4. cache_get_row_count(rows);
    5. if(!rows)
    6. {
    7. print("Загружено [0] бизнесов. Таблица с бизнесами пуста!");
    8. return 0;
    9. }
    10. else if(rows >= sizeof(BizInfo))
    11. {
    12. printf("Внимание: в таблице с бизнесами слишком много строк. Увеличте массив BizInfo на %d, дабы исправить ошибку [%d|%d]", rows-sizeof(BizInfo), rows, sizeof(BizInfo));
    13. rows = sizeof(BizInfo);
    14. }
    15. new Float:x,
    16. Float:y,
    17. Float:z;
    18. for(new i = 0, j = 1; i < rows; i++, j++)
    19. {
    20. cache_get_value_name_int(i,"ID",BizInfo[j][bID]);
    21. cache_get_value_name(i,"NameBiz",BizInfo[j][bName],32);
    22. cache_get_value_name_int(i,"Type",BizInfo[j][bType]);
    23. cache_get_value_name_float(i,"EnterX", x);
    24. cache_get_value_name_float(i,"EnterY", y);
    25. cache_get_value_name_float(i,"EnterZ", z);
    26. cache_get_value_name_float(i,"ExitX",BizInfo[j][bExitX]);
    27. cache_get_value_name_float(i,"ExitY",BizInfo[j][bExitY]);
    28. cache_get_value_name_float(i,"ExitZ",BizInfo[j][bExitZ]);
    29. cache_get_value_name_int(i,"Interior",BizInfo[j][bInterior]);
    30.  
    31. BizInfo[j][bEnterX] = x;
    32. BizInfo[j][bEnterY] = y;
    33. BizInfo[j][bEnterZ] = z;
    34.  
    35. CreateDynamicMapIcon(x, y, z, BizInfo[j][bType],0xFFFFFFAA,0,-1,-1,400.0);
    36. CreateDynamicCP(x, y, z, 1.0, -1, -1, -1, 3.0);
    37. }
    38. printf("Загружено [%i] бизнесов.",rows);
    39. }
    Респект:
    @DeimoS
    @ziggi
    @Daniel_Cortez

  5. #5
    Аватар для DeimoS
    Модератор?

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    Цитата Сообщение от Dimon_Fanat Посмотреть сообщение
    Понял, спасибо!
    А еще такой вопрос, допустим у меня бизнес в базе данных начинается с 1, 0 бизнеса нет, но когда я ввожу команду /goto и тп к бизнесу 1, меня тп к бизнесу №2, а если введу №0 то тп к бизнесу 1.
    ID в базе данных никак не связан с ID на сервере. По крайней мере не должен быть связан.
    ID в базе (поле с AUTO_INCREMENT) нужен сугубо для работы с базой. Хочешь связать ID бизнеса на сервере с базой - создавай дополнительное поле и храни ID в нём, а потом, при выгрузке данных, используй этот ID в качестве индекса массива.
    Последний раз редактировалось DeimoS; 06.06.2018 в 17:17.
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

    Широко известно, что идеи стоят 0.8333 цента каждая (исходя из рыночной цены 10 центов за дюжину).
    Великих идей полно, на них нет спроса.
    Воплощение идеи в законченную игру требует долгой работы,
    таланта, терпения и креативности, не говоря уж о затратах денег, времени и ресурсов.
    Предложить идею просто, воплотить – вот в чём проблема

    Steve Pavlina

 

 

Информация о теме

Пользователи, просматривающие эту тему

Эту тему просматривают: 1 (пользователей: 0 , гостей: 1)

Ваши права

  • Вы не можете создавать новые темы
  • Вы не можете отвечать в темах
  • Вы не можете прикреплять вложения
  • Вы не можете редактировать свои сообщения
  •