Перейти к публикации
Поиск в
  • Дополнительно...
Искать результаты, содержащие...
Искать результаты в...
  • Нужна помощь?

    Создайте тему в соответствующем разделе
    Не нужно писать всё в чат!
  • Продаёте или покупаете?

    Пользуйтесь услугами гаранта
    Мы сделаем вашу сделку безопасной
  • Не хотите БАН?

    Пожалуйста, ознакомьтесь с нашими правилами
    Не нарушайте порядок
  • Загляните на рынок

    Там вы можете продать или купить
    Всё что касается игровых серверов
BorizzK

Спавн машин с проверкой общего кол-ва машин на сервере и рядом с координатами

Рекомендованные сообщения

Накрапал функций (по мотивам того что делали для 0.62 когда-то)

Проверяем сколько машин на сервере (кстати, кому известны координаты центра Черноруси и макс полезный радиус от центра где могут располагаться объекты?)

Если машин данного типа достаточно на карте, не спавним

Если не хватает, перед спавном проверяем нет ли машины рядом (что бы не заспавнить внутрь другой)

Если все норм, спавним

 

	int CheckNearObjects(vector pos, int radius, string objectClass) //Проверка обьектов поблизости
	{
		array<Object> nearest_objects = new array<Object>;
		array<CargoBase> proxy_cargos = new array<CargoBase>;
		Object object;
		string className;
		int objectcount = 0;
		
		GetGame().GetObjectsAtPosition(pos, radius, nearest_objects, proxy_cargos); 
		Print("::: SpawnCars.c ::: CheckNearObjects (EntityAI m_Object, int radius) ::: Radius: " + radius.ToString() + ", all nearest_objects: " + nearest_objects.Count().ToString());
		for ( int i = 0; i < nearest_objects.Count(); i++ )
		{
			object = nearest_objects.Get(i);
			className = object.GetType();
			if ( className == objectClass )
			{
					objectcount++;
					Print( "::: SpawnCars.c ::: CheckNearestObjects: found object " + objectcount.ToString() + ": " + object.ToString() + ", Type/Class: " + className + " !!!");
			}
		}
		return objectcount;
	}

	int SpawnCar(string m_Car_Class, TVectorArray spawn_Points, int max_Car_Count, float min_Car_Health, float max_Car_Health, bool damageallow) //Спавн машины по заданным параметрам
	{
		Print("::: SpawnCars.c ::: SpawnCar(" + m_Car_Class + ", " + spawn_Points.ToString() + ") :::");
		vector m_Car_Pos;
		EntityAI m_Car;
		int n_Car_Count = 0;
		int all_Car_Count = 0;
		int s_Car_Count = 0;
		array<string> m_Car_Equip_Array = new array<string>;
		
		if (m_Car_Class == "OffroadHatchback")
		{
				/* Так то же можно
				m_Car_Equip_Array.Insert("HatchbackWheel");
				m_Car_Equip_Array.Insert("HatchbackWheel");
				m_Car_Equip_Array.Insert("HatchbackWheel");
				m_Car_Equip_Array.Insert("HatchbackWheel");
				m_Car_Equip_Array.Insert("CarBattery");
				m_Car_Equip_Array.Insert("SparkPlug");
				m_Car_Equip_Array.Insert("EngineBelt");
				m_Car_Equip_Array.Insert("CarRadiator");
				m_Car_Equip_Array.Insert("HatchbackDoors_Driver");
				m_Car_Equip_Array.Insert("HatchbackDoors_CoDriver");
				m_Car_Equip_Array.Insert("HatchbackHood");
				m_Car_Equip_Array.Insert("HatchbackTrunk");
				*/
				//И так можно
				m_Car_Equip_Array = {"HatchbackWheel","HatchbackWheel","HatchbackWheel","HatchbackWheel","CarBattery","SparkPlug","SparkPlug","EngineBelt","CarRadiator","HatchbackDoors_Driver","HatchbackDoors_CoDriver","HatchbackHood","HatchbackTrunk"};
				//Проверяем
				m_Car_Equip_Array.Debug();
		}
		/*
		else if (m_Car_Class == "M3S")
		{
			//Тут заполняем массив комплектующими M3S
		}
		*/
		else
		{
			Print("::: SpawnCars.c ::: SpawnCar() ::: NO CAR / WRONG CLASS SPECIFIED :::");
			return s_Car_Count;
		}
		
		all_Car_Count = CheckNearObjects("7000 0 7000", 20000, m_Car_Class); //Можно отключить если сервер глючит при старте, тогда присовойте all_Car_Count значение - all_Car_Count = 1; (см ниже)
      	//all_Car_Count = 1;

		for ( int i = 0; i < spawn_Points.Count(); i++ )
		{
			m_Car_Pos = spawn_Points.Get(i);
			n_Car_Count = CheckNearObjects(m_Car_Pos, 10, m_Car_Class);
			
			Print("::: SpawnCars.c ::: n_Car_Count = " + n_Car_Count.ToString());
			
			if (s_Car_Count + all_Car_Count < max_Car_Count)
			{
				if (n_Car_Count < 1)
				{	
					m_Car = EntityAI.Cast(GetGame().CreateObject(m_Car_Class, m_Car_Pos, false, true));
					
					for ( int e = 0; e < m_Car_Equip_Array.Count(); e++ )
					{
						m_Car.GetInventory().CreateAttachment( m_Car_Equip_Array.Get(e) ); 
					}
						
					m_Car.SetAllowDamage(damageallow);
					m_Car.SetHealth("","",Math.RandomInt(min_Car_Health,max_Car_Health));
					Print("::: SpawnCars.c ::: Spawned car: " + m_Car.ToString() + ", Position: " + m_Car.GetPosition().ToString());
					if (m_Car)
					{
						s_Car_Count++;
					}
				}
				else
				{
					Print("::: SpawnCars.c ::: Car spawn not allowed at position: " + m_Car_Pos.ToString() + ", becouse nearest car with same class " + m_Car_Class + " found.");
				}
			}
			else
			{
				Print("::: SpawnCars.c ::: Car spawn not allowed becouse cars with same class " + m_Car_Class + " >= " + max_Car_Count.ToString());
			}
		}
		return s_Car_Count;
	}

 

Подключение

 

Правим по своему вкусу

Помещаем код в файл и размещаем в папке доступной серверу

 

В самом начале init.c

#include "$CurrentDir:\\путь\\путь\\имя файла с кодом.c

 

Далее в функции main вызываем спавн

 

		TVectorArray spawn_Points_Niva = {"6063 0 7871"}; //array with positions, for more cars write more positios in to array
		int SpawnCarsCarsCount = SpawnCar("OffroadHatchback", spawn_Points_Niva, 32, 100, 100, false); //Class, Positions, Max count, min health, max health, damage allow - true/false
		Print("::: SpawnCars.c ::: SpawnCars() ::: Spawned cars: " + SpawnCarsCarsCount.ToString()); //это просто каммент

 

Или просто

int SpawnCarsCarsCount;

SpawnCarsCarsCount = SpawnCar("M3S", {"6000 0 6000", "7000 0 8000"}, 44, 100, 100, false);

 

Но для M3S нужно прописать комплектуху в SpawnCar() в массив m_Car_Equip_Array

 

Ну вобщем разберетесь )))

 

 

Добавлено:

Альтернативный вариант от комьюнити:

 

Изменено пользователем 123new (история изменений)

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


Ссылка на сообщение
Поделиться на других сайтах
Забронировать это рекламное место


Заправка мащины полностью под завязку

 

Car car = Car.Cast(m_Car); //даункастим сущность машины в класс Сar
car.Fill(CarFluid.FUEL, 100); //заливаем топливо - первй параметр тип жижи, второй обьем
car.Fill(CarFluid.COOLANT, 100); //заливаем антифирз
car.Fill(CarFluid.OIL, 100); //заливаем масло
car.Fill(CarFluid.BRAKE, 100); //заливаем тормозуху

 

обьемы считаются в тысячных

от 1 (1.000 - максимум) до 0.001 (минимум)

Но я на всяк случай указал 100

 

Теперь все заврдится, ездит

Изменено пользователем BorizzK (история изменений)

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


Ссылка на сообщение
Поделиться на других сайтах

Доработал чуть-чуть скрипт/функции

 


	int CheckNearObjects(vector pos, int radius, string objectClass) //Проверка обьектов поблизости
	{
		array<Object> nearest_objects = new array<Object>;
		array<CargoBase> proxy_cargos = new array<CargoBase>;
		Object object;
		string className;
		int objectcount = 0;
		pos[1] = GetGame().SurfaceY( pos[0], pos[2] );
		GetGame().GetObjectsAtPosition(pos, radius, nearest_objects, proxy_cargos); 
		Print("::: CheckNearObjects (vector pos, int radius, string objectClass) ::: Radius: " + radius.ToString() + ", all nearest_objects: " + nearest_objects.Count().ToString());
		for ( int i = 0; i < nearest_objects.Count(); i++ )
		{
			object = nearest_objects.Get(i);
			className = object.GetType();
			if ( className == objectClass )
			{
					objectcount++;
					Print( "::: CheckNearestObjects: found object " + objectcount.ToString() + ": " + object.ToString() + ", Type/Class: " + className + ", Pos: " + object.GetPosition().ToString());
			}
		}
		return objectcount;
	}

	int SpawnCar(string m_Car_Class, TVectorArray spawn_Points, int max_Car_Count, float min_Car_Health, float max_Car_Health, bool damageallow) //Спавн машины по заданным параметрам
	{
		Print("::: SpawnCars.c ::: SpawnCar(" + m_Car_Class + ", " + spawn_Points.ToString() + ") :::");
		vector m_Car_Pos;
		EntityAI m_Car;
		int n_Car_Count = 0;
		int all_Car_Count = 0;
		int s_Car_Count = 0;
		array<string> m_Car_Equip_Array = new array<string>;
		array<string> m_Car_Adds_Array = new array<string>;
		float amount =0;
		
		if (m_Car_Class == "OffroadHatchback")
		{
				m_Car_Equip_Array = {"HatchbackWheel","HatchbackWheel","HatchbackWheel","HatchbackWheel","CarBattery","SparkPlug","SparkPlug","EngineBelt","CarRadiator","HatchbackDoors_Driver","HatchbackDoors_CoDriver","HatchbackHood","HatchbackTrunk","HeadlightH7","HeadlightH7"};
				m_Car_Adds_Array = {"CanisterGasoline"};
				//Проверяем
				m_Car_Equip_Array.Debug();
				m_Car_Adds_Array.Debug();
				amount = 1;
		}
		else if (m_Car_Class == "M3S")
		{
			//Тут заполняем массив комплектующими M3S
		}
		else
		{
			Print("::: SpawnCars.c ::: SpawnCar() ::: NO CAR / WRONG CLASS SPECIFIED :::");
			return s_Car_Count;
		}
		if (m_Car_Equip_Array.Count() <= 0)
			return s_Car_Count;
		
		all_Car_Count = CheckNearObjects("7500 0 7500", 15000, m_Car_Class);
		Print("::: SpawnCars.c ::: SpawnCar() ::: All cars " + m_Car_Class + " on server: " + all_Car_Count.ToString());
		
		for ( int i = 0; i < spawn_Points.Count(); i++ )
		{
			m_Car_Pos = spawn_Points.Get(i);
			n_Car_Count = CheckNearObjects(m_Car_Pos, 30, m_Car_Class);
			
			Print("::: SpawnCars.c ::: Near cars " + m_Car_Class + " at selected pos " + m_Car_Pos.ToString() + ": " + n_Car_Count.ToString());
			
			if (s_Car_Count + all_Car_Count < max_Car_Count)
			{
				if (n_Car_Count < 1)
				{	
					Print("::: SpawnCars.c ::: Spawn: " + m_Car_Class);
					m_Car = EntityAI.Cast(GetGame().CreateObject(m_Car_Class, m_Car_Pos, false, true));
					
					for ( int e = 0; e < m_Car_Equip_Array.Count(); e++ ) //Attachments
					{
						m_Car.GetInventory().CreateAttachment( m_Car_Equip_Array.Get(e) ); 
					}
					
					for ( int a = 0; a < m_Car_Adds_Array.Count(); a++ ) //Adds //TEST
					{
						m_Car.GetInventory().CreateAttachment( m_Car_Adds_Array.Get(a) ); 
					}
					
					if (m_Car)
					{
						Car car = Car.Cast(m_Car); 
						car.Fill(CarFluid.FUEL, 1000); //add fuel
						car.Fill(CarFluid.COOLANT, 1000); //add antifreeze
						car.Fill(CarFluid.OIL, 1000); //add engine oil
						car.Fill(CarFluid.BRAKE, 1000);//add brake fluid
						m_Car.SetAllowDamage(damageallow);
						m_Car.SetHealth("","",Math.RandomInt(min_Car_Health,max_Car_Health));
						s_Car_Count++;
						Print("::: SpawnCars.c ::: Spawned car " + s_Car_Count.ToString() + ": " + m_Car.ToString() + ", Position: " + m_Car.GetPosition().ToString());
						Print("::: SpawnCars.c ::: Spawned car " + s_Car_Count.ToString() + ": FUEL amount   : " + car.GetFluidFraction( CarFluid.FUEL ).ToString());
						Print("::: SpawnCars.c ::: Spawned car " + s_Car_Count.ToString() + ": COOLANT amount: " + car.GetFluidFraction( CarFluid.COOLANT ).ToString());
						Print("::: SpawnCars.c ::: Spawned car " + s_Car_Count.ToString() + ": OIL amount    : " + car.GetFluidFraction( CarFluid.OIL ).ToString());
						Print("::: SpawnCars.c ::: Spawned car " + s_Car_Count.ToString() + ": BRAKE amount  : " + car.GetFluidFraction( CarFluid.BRAKE ).ToString());
					}
				}
				else
				{
					Print("::: SpawnCars.c ::: Car spawn not allowed at position: " + m_Car_Pos.ToString() + ", becouse nearest car with same class " + m_Car_Class + " found.");
				}
			}
			else
			{
				Print("::: SpawnCars.c ::: Car spawn not allowed becouse cars with same class " + m_Car_Class + " >= " + max_Car_Count.ToString());
			}
		}
		return s_Car_Count;
	}

	void SpawnCars() //Вызов спавна машин
	{
		TVectorArray spawn_Points_Niva = {"6063 0 7871"}; //array with positions, for more cars write more positios in to array
		int SpawnCarsCarsCount = SpawnCar("OffroadHatchback", spawn_Points_Niva, 32, 100, 100, false); //Class, Positions, Max count, min health, max health, damage allow - true/false
		Print("::: SpawnCars.c ::: SpawnCars() ::: Spawned cars: " + SpawnCarsCarsCount.ToString());
		SpawnCarsCarsCount = SpawnCar("M3S", {"6000 0 6000"}, 30, 100, 100, false); //Class, Positions, Max count, min health, max health, damage allow - true/false
		Print("::: SpawnCars.c ::: SpawnCars() ::: Spawned cars: " + SpawnCarsCarsCount.ToString());
	}

 

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


Ссылка на сообщение
Поделиться на других сайтах

После подключения скрипта сервер при старте начинает жрать всю оперативку в ноль просто.

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


Ссылка на сообщение
Поделиться на других сайтах

HornetNova  жрет так как функция

all_Car_Count = CheckNearObjects("7500 0 7500", 15000, m_Car_Class);

грузит сервер крайне дико и сильно, т.е. функция выполняет поиск объектов от указанной точки по радиусу в указанном диапазоне, и если учесть, что в нее попадает вообще все (т.е. лут, здания, игроки, животные, зомби и т.п.), то поиск из этого огромного массива естественно будет выполняться долго.

нужна альтернатива для sqf как (AllMissionObjects "car"), но увы, в новом языке я даже похожего ничего не встречал.

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


Ссылка на сообщение
Поделиться на других сайтах

123new ничего подобного нет

Потому проверяем все обьекты

Знать бы точные координаты центра карты и макс радиус где обьекты могут быть, проверку можно было бы оптимизировать

 

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


Ссылка на сообщение
Поделиться на других сайтах
3 минуты назад, BorizzK сказал:

123new ничего подобного нет

Потому проверяем все обьекты

Знать бы точные координаты центра карты и макс радиус где обьекты могут быть, проверку можно было бы оптимизировать

 

В дайзе в данный момент только 1 массив содержит все объекты. - Проверять устанешь. Комп повиснет.

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


Ссылка на сообщение
Поделиться на других сайтах

NoNameUltima Я сервак запускаю на Core I7 7700 и Xeon E5-2650v4 + 32гиг памяти + ссд

Проверка дефолтных обьектов во время запуска сервера после 3го рестарта через сутки + еще натащили юзвери + я наспавнил  - занимает порядка 30-40 сек

Обьектов всего порядка 4млн

Так что не страшно

 

Можно запулить спавн машин и проверку в фоне после старта сервера и проверять секторами

Над будет заморочиться

 

PS Рад что ты не свалил с форума )))

 

 

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


Ссылка на сообщение
Поделиться на других сайтах

BorizzK я даже в фоне запустил проверку от точки по дистанции, увы, но думал комп прийдется с кнопки перезагружать.

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


Ссылка на сообщение
Поделиться на других сайтах

BorizzK FX-6350, GTX970, 8GB оперативка. Знаю, железо далеко не серверное, но и не ставил цели запускать полноценный сервер на нем, исключительно для теста скриптов

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


Ссылка на сообщение
Поделиться на других сайтах

123new И сколько по времени занимает страт сервера с переборкой всех объектов после 3го рестарта?

При условии что клиент не запущен

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


Ссылка на сообщение
Поделиться на других сайтах

Вобщем проверил

 

1. Серв с 16 гиг памяти и core i7 7700

2. Диски SAS6 10000rpm 10 райд

3. Серв после 5го рестарта

5. 10 игроков в сумме чет там понастроили и тп

6. Нив 40 штук

7. Еще немного наспавлено всякой фигни для тестов

 

При проверке всех обьектов на сервере серверу надо около 8-9гиг памяти сверху

Те он отжирает сначала 6-7 затем во время проверки доходит до 13-14 и потом падает до тех же 6-7

Времени занимает  20-22 секунды

Переносил серв  на SSD - 21 секунду

На зеркало SATA 28 секунд

Нагрузка на проц при этом была больше на 2-3%

Затем память освобождалась и падала нагрузка до обычных значений

при этом если проводить проверку повторно, то она проходит в неск раз быстрей - 2-5секунд
Сколько проверок не запускай

ради интереса наспавнил 500 машин и еще порядка 25000 разных обьектов по всей карте

Тогда проверка заняла на 1-3 сек больше, но памяти сожрало столько же

 

Вобщем нормальному серверу дейз нужно не менее 12-16 гиг памяти

Ибо если начинает свапиться, будут те самые тормоза и зависоны

 

 

Изменено пользователем BorizzK (история изменений)

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


Ссылка на сообщение
Поделиться на других сайтах

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

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


Ссылка на сообщение
Поделиться на других сайтах

Ну как бы каждый сам решает пользовать аль нет

Однако в виртуалке 4 ядра

16 гиг памяти

20 сек при старте при первой проверке и 2-3 сек при каждой последующей - не вижу проблем

Кроме того на хостинге - любом тебе выделяют виртуалку и только ее ты мжешь загрузить

по опыту - хоть обзагружайся

повлиять на других ты не можешь - гипервизор не даст

потому выделили тебе 16 гиг памяти и 4 ядра по 2ггц - можешь хоть все время их на 100% грузить - ибо ОПЛАЧЕНО

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


Ссылка на сообщение
Поделиться на других сайтах

Щас бы сравнивать 16-20 гиг и 8 гиг оперативки, ага))

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

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


Ссылка на сообщение
Поделиться на других сайтах

123new Не заметил влияния

Ну и не замена эта оф спавнеру

Это допспавнер как бы

А про память - для дом компа сейчас норма 12-16

А для сервера от 16 и до потолка

В идеале хост под 2 игровых сервера - 32 гига (по 12 на виртуалку и 10 расшарено) - те каждая может пользовать при необходимости, ну это уже гипервизор разруливает) + еще от 1-2 гиг на гипервизор если это vmware vsphere и от 8 если hyper-v - итого около 40

 

 

Изменено пользователем BorizzK (история изменений)

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


Ссылка на сообщение
Поделиться на других сайтах

BorizzK это кто же эти нормы установил? вот сижу я со своими 8 гигами и ни в ус не дую, все устраивает, и нахрен мне эти 12-18 гигов не сдались. Больше на подгон под общие стандарты подходит.

Изменено пользователем 123new (история изменений)

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


Ссылка на сообщение
Поделиться на других сайтах

123new ну вот у меня 32 на одном 16 на втором

на серваках (железных) 128, 256, есть и 1Тб
виртуалкам выделяю скок надо и без проблем

вчера коллеги активно пвпэшились и друзей позвали - собралось их аж 40 рыл, пришлось увеличивать кол-во игроков

так сервер в итоге на второй час почти 14 гиг жрал

и это без доспавна машин

 

Изменено пользователем BorizzK (история изменений)

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


Ссылка на сообщение
Поделиться на других сайтах

BorizzK не, то что названо это точно что-то не для рядового домашнего ПК на данный момент. Собственно, скрипт интересный, но тот еще костыль, думаю лучше более адекватного решения дождаться

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


Ссылка на сообщение
Поделиться на других сайтах

123new Да ясно что костыль, но за неимением лучшего... Сам понимаешь...

Давай лучше подумаем насчет, что за косяк при создании стартового лута...

 

 

 

 

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


Ссылка на сообщение
Поделиться на других сайтах

Присоединяйтесь к обсуждению

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

Гость
Ответить в тему...

×   Вставлено в виде отформатированного текста.   Восстановить форматирование

  Разрешено не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отобразить как ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставить изображения напрямую. Загрузите или вставьте изображения по ссылке.

Загрузка...

  • Похожие публикации

    • Автор: NoNameUltima
      Автор:
      Я
       
      Цена:
      1500
       
      Тип:
      Клиент+Сервер(2 мода, - клиентский есть в стиме)
       
      Описание работы:
       
      Торговец появляется в определенном месте, с определенным товаром. По истечении определенного времени, торговец перемещается на другую точку.
      Точки торговца, товар, время перемещения задаются в конфигурации.
       
      Пример конфигурации:
      В профиль копируем пример конфига.
       
      Открываем файл:
      UST_SERVER_STRING_TRADERS_FILE.txt
       
      Добавляем конфиги с файлами торговцев
      300|Ultima_Trader_Plus_Black_Market_0.txt
      600|Ultima_Trader_Plus_Black_Market_1.txt
      *тут - время в секундах, которое торговец стоит на месте. И файл с координатами торговца.
       
      Открываем папку
      UST_SERVER_STRING_TRADERS_FOLDER
      Создаем в ней 2 файла указанных выше, и наполняем их координатами:
       
      Пример:
      Ultima_Trader_Plus_Black_Market_0.txt
      6123.73 299.331 7616.21
      6130.73 299.331 7616.21
      6115.73 299.331 7616.21
       
      *ВАЖНО - ВЕРХНЯЯ КООРДИНАТА(ПЕРВАЯ) ОБЯЗАТЕЛЬНО ДОЛЖНА СОВПАДАТЬ С КООРДИНАТОЙ ТОРГОВЦА ИЗ МОДА ТРЕЙДЕРА!
       
      Торговец будет телепортироваться по данным координатам, случайным образом, каждые 5мин(300с).
    • Автор: NoNameUltima
      Автор: NoNameUltima
      v R5
      Стоимость: 9500
       
      Мод предоставляется в нескольких частях:
      Со стима:
      Клиентский мод со стима Ultima(для игроков). Ключи и подписи, присутствуют.   Клиентский мод со стима UltimaClientAdmin(для игроков). Ключи и подписи, присутствуют.   Клиентский мод для Вашего сервера! Данный мод необходимо будет переименовать(в любое имя - это Ваш мод, модифицирующий конфиг). Необходимо будет создать к нему ключи и подписи, и выложить от себя в стим. Ссылку на данный мод вы и выкладываете в стим. Серверные мод(только для сервера). Кол-во: 2. *Моды связанны между собой.
       
      Что присутствует:
      Стартовое меню:
      Добавлена ссылка на группу в ВК. Добавлена ссылка на Дискорд. Добавлен выбор для прямого захода на Ваши сервера!(возможно добавление множества серверов в одно меню). Добавлен логотип. Добавлен экран(картинка) загрузки. Добавлен экран(картинка) возрождения\захода на сервер. *Все описанные выше параметры настраиваются под Ваш сервер! Дебаг монитор:
      Донат Наличные Банк Убито людей Убито зомби Фракция Репутация Игроков онлайн ФПС Время старта миссии Время до рестарта Собственная валюта:
      Можно забрать из трупа по экшену мышки(обыскать карманы) Можно положить в банк(Размер банковской ячейки - настраивается). Можно перевести другому игроку Можно совершать покупки *Валюта виртуальная. Фракции:
      Возможность создать фракцию, за валюту, или чеки(донат).(Ценники настраиваются в конфигурации). Возможность удалить фракцию. Возможность приглашения игроков во фракцию.(Ограничение на кол-во игроков во фракции задается в конфигурации). Возможность выгнать игрока из фракции. Возможность отклонить приглашение во фракцию. Возможность принять приглашение во фракцию. Отображение имени игрока над головой, если он в одной фракции с вами, и на дистанции менее 100м. Возможность создавать точки возрождения для членов фракции.(Кол-во точек и стоимость создания настраиваются в конфигурации). Безопасные зоны:
      Удалены зомби из безопасных зон Удалены волки из безопасных зон Отключен урон по игрокам внутри безопасных зон Нельзя перейти в боевой режим внутри безопасных зон Отображение имен игроков внутри торговых зон Оповещение при входе Оповещение при выходе Торговые зоны:
      Над торговцами присутствует надпись(чем торгует) Взаимодействие с торговцами через экшен мышки(торговля) Зона запрета строительства:
      Нельзя строить. Торговля:
      Торговля может быть настроена на определенную фракцию При продаже учитывается процент повреждения объекта, и торговец даст за него сумму с учетом повреждений! Владельцем техники считается тот игрок, кто последний сидел за рулем, и именно она и  отображается в продаже. Продаваемая техника должна быть в пределах 10м от игрока. При покупке техники, ключ выдается автоматически. Нельзя продать технику если в ней кто то находится. Нельзя вести торговлю находясь внутри техники. При продаже объекта, весь инвентарь, в т.ч. и обвес который находился внутри объекта(к примеру рюкзака, или техники), будет автоматически сложен под ноги. Есть возможность создать "бродячего" торговца. - Файл с конфигурацией прилагается.( Настраивается время перемещения, и список случайных позиции для торговца) Техника:
      Есть возможность привязать технику к ключу, предварительно купив его у торговца. Есть возможность закрывать технику на ключ. Владельцем техники считается тот, кто последним сидел за рулем. После рестарта, вся техника которая привязана к ключам создается закрытой. Экшен перевернутой техники (постановка на колеса), при наличии монтировки. Только тому игроку который последним сидел за рулем. Карта:
      Добавлена карта для игроков, открытие на CTRL+M Установка маркера на карту Дабл.клик ЛКМ.(Будет отображен и в ESP)*При наличии компаса в инвентаре Удаление маркера с карты Дабл клик ПКМ.*при наличии компаса в инвентаре Отображение азимута при наличии компаса в инвентаре. Монитор возрождения:
      Добавлены точки для выбора места возрождения. Возможность добавлять стандартные точки возрождения. Возможность добавлять точки возрождения за валюту в банке. Возможность добавлять точки возрождения за чеки(донат). Возможность добавлять точки возрождения зависящие от репутации(-+) *Данные точки отображаются у игроков в мониторе возрождения. Так же отображаются фракционные точки, если игрок состоит во фракции, и у фракции они созданы. Оповещения о смертях:
      Отдельное уведомление в окошке. Стартовый инвентарь:
      Есть возможность выдавать инвентарь как по UID, при чем случайным образом из списка доступных для данного UID'а. Игроки для которых не создан конфиг инвентаря, получают его из общего конфига. В конфиге можно указать одежду, вещи которые будут помещены в руки, вещи которые будут помещены горячие слоты, а так же есть возможность добавлять вещи сразу в комплектации(т.е. с обвесом, батарейками и т.п.) Репутация:
      При смерти с игрока снимается 200 репутации(до 0 в +-). т.е. Пример:
      Было +450, станет +250.
      Было -300, станет -100.
      Было +90, станет 0.
      Было -150, станет 0.
      За убийство игрока, репутация начисляется по 150 таким образом: Если с убитого снято менее 200 репутации(см. пример выше), то начисления нет! Если убийца был с отрицательной репутацией, то начисление идет в минус. Пример:
      Было -100, станет -250
      *Не играет роли, какая репутация была у убитого.
      Если убийца был с положительной репутацией, а убитый с отрицательной, то +150 Пример:
      Было 100, станет 250
      Если убийца был с положительной репутацией, и убитый с положительной , то -150 Пример:
      Было 100, станет -50
      Было 1000, станет 850
      Стартовые позиции игроков:
      Есть возможность возрождать игрока на точках прописанных специально под его UID, при чем случайным образом из списка доступных для данного UID'а. Игроки для которых не создан конфиг возрождения, возрождаются из общего конфига. Журналы:
      Торговля Посадка\Высадка в\из технику(и) Установка\деммонтаж(стройка) Смерти игроков АДМИНКА (ВКЛЮЧЕНА В МОД):
      Все пункты описывать не буду, - могу сказать только то, что все работает, и множество пунктов, такие как выдача наличных, смена фракции и т.п. сделанны специально под модификацию. СЕРВЕРНЫЕ МОДЫ:
      Настраиваются под Ваш сервер, и имею богатый функционал. доп. процедуры и функции.  
       
      В остальном смотрите видео по ссылке:
      *В данный момент, сервер с данным модом работает по адресам:
       
      185.247.140.7:2312
      *Версия R5
      **Для входа необходим мод сервера
      https://steamcommunity.com/sharedfiles/filedetails/?id=1735075579
       
      skype: hf-trade
      discord: https://discord.gg/T9YAJDm
       
      P.S. Обновления платные, если они вносят доп. функционал(для тех кто приобретал мод ранее: 25% от общей стоимости, до актуальной версии).
      P.S.P.S. Весь функционал является БЕТА-ВЕРСИЕЙ!
    • Автор: Serdce
      Ссылка на первоисточник - https://github.com/BrettNordin/Exile
      Я всего лишь перевёл
      Собственно переходим по ссылке, и скачиваем архив.
      Для тех, кто не знает как качать с хаба скрин 
      И так, едем дальше
      Скачанный архив распаковываем в удобное место для работы,
      Идём в ваш @ExileServer, там нас интересуют файлы - extDB2.dll , extDB2.so , extDB2-conf.ini , XM8.dll , XM8.so Удаляем эти файлы
      Далее идём в @ExileServer которую мы скачали, всё её содержимое копируем в аналогичную папку на сервере.
      Теперь идём в вашу MPmissions и там распаковываем вашу миссию "Exile.название карты",
      Туда мы копируем содержимое папки Exile.MapName из архива,
      Далее открываем ваш config.cpp и ищем там class CfgExileCustomCode 
      В него мы добавляем - #include "CfgExileCustomCode.cpp"
      Должно получится так
      Запаковываем обратно)
      Ну и теперь из архива мы копируем tbbmalloc.dll, tbbmalloc_x64.dll в папку расположения вашего Arma3_server.exe
      Не забываем поменять в вашем файле запуска сервера с arma3server.exe на arma3server_x64.exe 
      Ну и финишная прямая, открываем вашу базу данных ( желательно с название exile ) и добавляем файл Exile_Database_Update_64x.sql
      Далее настройте под себя ваш extdb3-conf.ini
       
    • Автор: BorizzK
      Ктонить разбирался с этим?
      С зомбями все понятно
      А вот с энималсами?
       
      Как я не ковырял, как не пытался - не хотят спавнится отдельно собачки
       
      Есть идеи?
×
×
  • Создать...