Вопросы

Спойлер

#define vehicle_type_server     1
#define vehicle_type_player     2
#define vehicle_type_job        3
#define vehicle_type_admin      4

enum vehicle
{
    id,
    type,
    model,
    vehicle_id,
    owner,
    color[2],
    Float:position[4],
    Float:fuel,
    Float:milage,
    Float:health,
    bool:locked
   
}

new veh_info[MAX_VEHICLES][vehicle];

CMD:lock(playerid)
{
    if(IsValidVehicle(GetPlayerVehicleID(playerid)))
    {
        new vehicleid = GetPlayerVehicleID(playerid);
        if(veh_info[vehicleid - 1][type] != vehicle_type_player || veh_info[vehicleid - 1][owner] != PlayerInfo[playerid][id]) return SendClientMessage(playerid, color_gray,"Нет ключей от транспорта.");
        PlayerPlaySound(playerid, 11450.00.00.0);
        //сток блокировки дверей
        return 1;
    }
    else
    {
        new Float:x,
            Float:y,
            Float:z;
           
        GetVehiclePos(); // тут вроде должны получить коорды авто
        IsPlayerInRangeOfPoint() // чекнуть находится ли игрок в радиусе с авто
    }
    return 1;
}

callback: users_vehicles_loading()
{
    new rows, fields;
   
    cache_get_data(rows, fields);
   
    if(rows)
    {
        for(new i = 0; i < rows; i++)
        {
            veh_info[i][type] = vehicle_type_player;
           
            veh_info[i][id] = cache_get_field_content_int(i, "v_id", sql_connection);
            veh_info[i][model] = cache_get_field_content_int(i, "v_model", sql_connection);
            veh_info[i][owner] = cache_get_field_content_int(i, "v_owner", sql_connection);
            veh_info[i][color][0] = cache_get_field_content_int(i, "v_color_1", sql_connection);
            veh_info[i][color][1] = cache_get_field_content_int(i, "v_color_2", sql_connection);
           
            veh_info[i][fuel] = cache_get_field_content_int(i, "v_fuel", sql_connection);
            veh_info[i][milage] = cache_get_field_content_int(i, "v_milage", sql_connection);
           
            veh_info[i][position][0] = cache_get_field_content_int(i, "v_pos_x", sql_connection);
            veh_info[i][position][1] = cache_get_field_content_int(i, "v_pos_y", sql_connection);
            veh_info[i][position][2] = cache_get_field_content_int(i, "v_pos_z", sql_connection);
            veh_info[i][position][3] = cache_get_field_content_int(i, "v_pos_a", sql_connection);
           
            veh_info[i][vehicle_id] = CreateVehicle(veh_info[i][model], veh_info[i][position][0], veh_info[i][position][1], veh_info[i][position][2], veh_info[i][position][3], veh_info[i][color][0], veh_info[i][color][1], 5001);
        }
    }
   
    printf("Автомобилей игроков загружено: %d", rows);
    return 1;
}

 

Не много не понимаю как реализовать открытие/закрытие авто с определенного радиуса. Помогите пожалуйста). Хранение автомобилей сделал в базе данных. Расскажите пожалуйста это хорошо (в плане оптимизации/будущих апдейтов, т.к. планирую хранить не только игровой транспорт, но и аренды,фракций и т.д.)?

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

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


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

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

  • 0

@NO2037, немного нехорошо в плане дальнейшего ведения проекта (зачем использовать иностранные слова там, где суть можно передать русскими? Это я про апдейты) – использовать макросы (директивы #define) там, где можно и даже нужно использовать перечисления (enum).

enum {
    VEHICLE_TYPE_SERVER = 1,
    VEHICLE_TYPE_PLAYER, // и не нужно указывать номер: нумерация идет автоматически
    VEHICLE_TYPE_JOB,
    VEHICLE_TYPE_ADMIN
};

 

Если же вопрос заключался в самой идее хранения всевозможных типов транспорта (правда слово тип меня здесь смущает) в базе данных, так я и сам приверженец того, что вы реализованы. Вообще все, что можно хранить отдельно, имеет смысл хранить отдельно. На некоторых игровых проектах, например, весь маппинг хранится тоже в базе данных. Это позволяет разработчикам игровых карт редактировать их так, как они считают нужным, и вносить изменения на сервер, не прикасаясь к игровому моду и базе данных, вручную, а также не отвлекая от своих дел разработчиков игрового мода.

 

Касаемо вопроса реализации.

Спойлер

CMD:lock(playerid) {

    static const Float:LOCK_MAX_DISTANCE = 20.0// радиус действия команды от автомобиля

    new vehicleid = GetPlayerVehicleID(playerid); // если vehicleid = 0, значит игрок не в т/с; иначе – внутри т/с
    if (vehicleid == 0) { // игрок не в автомобиле => дистанционное открытие/закрытие
        for (new i = 0; i < MAX_VEHICLES; i++) { // ищем все т/с рядом с игроком
            if (!IsValidVehicle(veh_info[i][vehicle_id])) { // если транспорта не существует
                continue// уходим на следующую итерацию
            }

            new Float:x, Float:y, Float:z; // лучше вне цикла, но, думаю, компилятор оптимизирует объявление переменных сам
            GetVehclePos(i, x, y, z);

            if (GetPlayerDistanceFromPoint(playerid, x, y, z) > LOCK_MAX_DISTANCE) { // слишком далеко находится транспортное средство
                continue// уходим на следующую итерацию
            }

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

            // как только убедились, что рядом есть транспортное средство и мы можем его открыть
            // сохраняем ID этого транспортного средства и выходим из цикла
            vehicleid = i;
            break;
        }

        if (vehicleid == 0) { // если так и не нашли ни одно т/с рядом с игроком, которое он может открыть
            return SendClientMessage(playerid, -1"Рядом нет т/с, которые вы можете открыть/закрыть") & 0;
        }
    }

    // теперь в vehicleid записан ID т/с, которое мы можем открыть/закрыть. Осталось лишь сделать это
    PlayerPlaySound(playerid, 11450.00.00.0);
    // вызов функции открытия/блокировки дверей

    return true;
}

 

 

---

И давайте все же называть вещи своими именами. Есть переменные, есть функции, есть маркеры (они же ключевые слова). Выражение "сток блокировки дверей" – это все, что сказать "статик блокировки дверей". И нельзя говорить, что ключевые слова stock или public относятся к функциям – с таким же успехом могут быть объявлены и переменные с маркерами stock и public.

 

Спойлер


/*
    глобальная переменная
    область видимости ограничена одним файлом
    (доступ к переменной возможен только из этого файла)
*/

static var = 0;
static const var = 0// аналогично, но нельзя изменить значение

static stock var = 0// если переменная не используется, компилятор ее выбросит
static const stock var = 0// аналогично

/*
    глобальная переменная
    доступ к переменной возможен из любой точки ниже объявления данной переменной
    в примерах ниже показано, что new можно опускать
*/

new var = 0;
new stock var = 0// если переменная не используется, компилятор ее выбросит
stock var = 0// то же самое

new const var = 0// аналогично, но нельзя изменить значение
const var = 0// то же самое
const stock var = 0// то же самое

/*
    глобальная публичная переменная
    обратиться к переменной можно из фильтрскриптов
*/

new public var = 0;
new public stock var = 0// если переменная не используется, компилятор ее выбросит
new public const var = 0// переменную нельзя изменить
new public const stock var = 0;

public var = 0// ключевое слово new можно упускать
public const var = 0;
public const stock var = 0;

/*
    статические функции
*/

static someFunc() {
    // доступ к функции возможен только из этого файла
}

static stock someFunc() {
    // доступ к функции возможен только из этого файла
    // если функция не используется, компилятор ее выбросит
}

/*
    глобальные функции
*/

someFunc() {
    // и не нужен никакой stock
    // это самая обычная функция
}

stock someFunc() {
    // а это обычная функция
    // но если она не используется, компилятор ее выкинет
}

/*
    глобальные публичные функции
*/

forward someFunc();
public someFunc() {
    // доступ к функции возможен из фильтрскриптов
}

@someFunc();
@someFunc() {
    // это то же самое, что и forward + public
    // главное, чтобы первый символ был @
    // тогда ключевые слова forward и public писать не нужно
}

 

 

 

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


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

@Cawfee Ну я так описал вкратце.. смысл я думаю был понятен). Ошибки понял, исправим. Благодарю за столь обширный и информативный ответ.

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

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


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

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

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

    • Aleksey98
      От Aleksey98
      Необходим человек: который сможет написать систему тюнинга!
      как на крупных проектах типа: Arizona и Radmir
      И еще требуется Мапперы на новый топовый проект!
      Связь : https://vk.com/id289498732
    • 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} };