Jump to content

Recommended Posts

Posted

Hi! im modifying this script to show damage on screen, when you use a normal hit or evade, blocked it works fine but i would like to show a Message "Magic Critical" or "Critical" when the player hits. Im confused and i dont understand where i need to edit the code. Does anybody hava a idea anda could give me a hand?.
THanks!

 

I share the code here. In advance i will add +exp gained too.

 

class OnScreenDmg extends UICommonAPI;

const REFRESH_TARGETS_NUMBER_TIMERID = 7777;

const START_1_TEXT_TIMERID = 1001;
const START_2_TEXT_TIMERID = 1002;
const START_3_TEXT_TIMERID = 1003;
const START_4_TEXT_TIMERID = 1004;

const MIDDLE_TEXT_TIMERID = 2000;
const MIDDLE_1_TEXT_TIMERID = 2001;
const MIDDLE_2_TEXT_TIMERID = 2002;
const MIDDLE_3_TEXT_TIMERID = 2003;
const MIDDLE_4_TEXT_TIMERID = 2004;
const MIDDLE_5_TEXT_TIMERID = 2005;
const MIDDLE_6_TEXT_TIMERID = 2006;
const MIDDLE_7_TEXT_TIMERID = 2007;
const MIDDLE_8_TEXT_TIMERID = 2008;
const MIDDLE_9_TEXT_TIMERID = 2009;
const MIDDLE_10_TEXT_TIMERID = 2010;
const MIDDLE_11_TEXT_TIMERID = 2011;
const MIDDLE_12_TEXT_TIMERID = 2012;

const FINISH_1_TEXT_TIMERID = 3001;
const FINISH_2_TEXT_TIMERID = 3002;
const FINISH_3_TEXT_TIMERID = 3003;
const FINISH_4_TEXT_TIMERID = 3004;
const FINISH_5_TEXT_TIMERID = 3005;
const FINISH_6_TEXT_TIMERID = 3006;
const FINISH_7_TEXT_TIMERID = 3007;
const FINISH_8_TEXT_TIMERID = 3008;

var WindowHandle Me;
//var TextBoxHandle MainDmg;
//var TextBoxHandle pText;

var TextBoxHandle txt_Damage[12];

//var TextBoxHandle txt_ClassicDamage1;
//var TextBoxHandle txt_ClassicDamage2;
//var TextBoxHandle txt_ClassicDamage3;
//var TextBoxHandle txt_ClassicDamage4;
//var TextBoxHandle txt_ClassicDamage5;
//var TextBoxHandle txt_ClassicDamage6;
//var TextBoxHandle txt_ClassicDamage7;
//var TextBoxHandle txt_ClassicDamage8;
var TextBoxHandle txt_Critical;
var TextBoxHandle txt_Multiplier;

var TextBoxHandle txt_Level;

var int WeapType;
var int reflectFilter;	// value to filter reflect damage
var int my_ID;
var int mypet_ID;
var int targetCount;
var int otherCount;

var int messagePosition;
var string  damageString[4];
var int  colorString[4];

var bool isAttackingDmg;
var int	freeTextPosition[8];
	//		freeTextPosition2,
	//		freeTextPosition3,
	//		freeTextPosition4;
var bool isCrit;
var bool showOSD;
var bool showMult;

var Color DefaultColor;
var Color Yellow;
var Color Red;

function OnLoad ()
{	
	local int temp;
	
	Me = GetWindowHandle("OnScreenDmg");
	
	for (temp = 0; temp < 12; temp++)
	{
		txt_Damage[temp] = GetTextBoxHandle("OnScreenDmg.txtDamage" $ temp);
	}

	txt_Critical = GetTextBoxHandle("OnScreenDmg.txtCritical");
	txt_Multiplier = GetTextBoxHandle("OnScreenDmg.txtMultiplier");
	
	txt_Level = GetTextBoxHandle("StatusWnd.txtLevel");
	
	DefaultColor.R = 216;
	DefaultColor.G = 216;
	DefaultColor.B = 216;
  
	Yellow.R = 255;
	Yellow.G = 225;
	Yellow.B = 73;
	
	Red.R = 255;
	Red.G = 153;
	Red.B = 153;
	
	showOSD = false;
	showMult = false;
	
	GetINIBool("WindowsCheks", "OnScreenDmg", temp, "PatchSettings");
	if (temp == 1)
	{
		showOSD = true;
	}

	GetINIBool("WindowsCheks", "Multiplier", temp, "PatchSettings");
	if (temp == 1)
	{
		showMult = true;
	}

	targetCount = 0;
	otherCount = 0;
	mypet_ID = -1;
	my_ID = -1;
	
//	txt_ClassicDamage1.SetAlpha(0);
	//txt_ClassicDamage2.SetAlpha(0);
	txt_Multiplier.SetAlpha(0);
	txt_Critical.SetAlpha(0);
	txt_Critical.HideWindow();
}


function OnRegisterEvent ()
{
	RegisterEvent(EV_UpdateUserInfo);
	RegisterEvent(EV_SystemMessage);
	RegisterEvent(EV_ReceiveMagicSkillUse);
	RegisterEvent(EV_ReceiveAttack);	
	RegisterEvent(EV_SummonedStatusShow);
	RegisterEvent(EV_PetStatusShow);
	RegisterEvent(EV_PetSummonedStatusClose);
}		

function OnEvent (int a_EventID, string a_Param)
{

	switch (a_EventID)
	{
		case EV_PetSummonedStatusClose:
			mypet_ID =-1;	
			break;
		case EV_UpdateUserInfo:
			if	(my_ID <= 0) my_ID = class'UIDATA_PLAYER'.static.GetPlayerID();
			reflectFilter = 5 + int(txt_Level.GetText());
			break;
		case EV_SummonedStatusShow:
			if (mypet_ID <= 0) mypet_ID = class'UIDATA_PET'.static.GetPetID();
			break;		
		case EV_PetStatusShow:
			if (mypet_ID <= 0) mypet_ID = class'UIDATA_PET'.static.GetPetID();
			break;
		case EV_SystemMessage:
			if (showOSD) HandleSystemMessage(a_Param);
			break;	
		case EV_ReceiveAttack:
			if (showOSD) AttackForDmg(a_Param);
			break;	
		case EV_ReceiveMagicSkillUse:
			if (showOSD) SkillCastForDmg(a_Param);
			break;				
	}
}

function OnEnterState( name a_PreStateName )
{
	local int i;
	
	if (a_PreStateName == 'LoadingState')
	{
			targetCount = 0;
			otherCount = 0;
			mypet_ID = -1;
			my_ID = -1;
			messagePosition = 0;
			
			for (i = 0; i < 8; i++)
				freeTextPosition[i] = 1;	
	}	
}

function SkillCastForDmg (string a_Param)
{
	local int AttackerID;
	local int SkillID;
	local int SkillLevel;
	local SkillInfo UsedSkill;

	ParseInt(a_Param,"AttackerID",AttackerID);
	if ((AttackerID != my_ID) && (AttackerID != mypet_ID)) return;
	
	ParseInt(a_Param,"SkillID",SkillID);	
	if (IsNotDisplaySkill(SkillID)) return;
	
	ParseInt(a_Param,"SkillLevel",SkillLevel);
	GetSkillInfo(SkillID, SkillLevel, UsedSkill);
	
	if ((my_ID == AttackerID && UsedSkill.IsMagic < 2 && (UsedSkill.OperateType == 0 || UsedSkill.OperateType == 1 || UsedSkill.OperateType == 3)) ||  (mypet_ID == AttackerID &&  UsedSkill.IsMagic == 1))
	{
	//	targetCount = 0;
		isAttackingDmg = false;
	}
}	
	

function AttackForDmg(string a_Param)
{
	local int AttackerID;

	ParseInt(a_Param,"AttackerID",AttackerID);	

	if (my_ID != AttackerID) return;
	else isAttackingDmg = true;	
}


function ShowOnScreenDamage (string textDamage, int textOrder, int textColor)
{
	local int userX;
	local int userY;
	local color Color;
	
	textDamage = textDamage $ " "; // obrezaetsya inogda

	GetCurrentResolution(userX, userY);

	switch (textColor)
	{
		case 0:
			Color = DefaultColor;
			break;
			
		case 1:
	//		txt_Critical.MoveTo(userX/2 + 65 , userY/2 - 50);
	//		txt_Critical.SetAlpha(255);
	//		txt_Critical.SetAlpha(0, 0.6f);			
			Color = Yellow;
			break;
			
		case 2:
			Color = Red;
			break;
	}

	txt_Damage[textOrder - 1].SetAlpha(0);
	txt_Damage[textOrder - 1].SetTextColor(Color);
		
	switch (textOrder)
	{
		case 1:
		case 5:
		case 9:
			txt_Damage[textOrder - 1].MoveTo(userX/2  - 110, userY/2 - 100);
			break;

		case 2:
		case 6:
		case 10:
			txt_Damage[textOrder - 1].MoveTo(userX/2 + 10, userY/2 - 100);
			break;
				
		case 3:
		case 7:
		case 11:
			txt_Damage[textOrder - 1].MoveTo(userX/2 - 50, userY/2 - 125);
			break;
				
		case 4:
		case 8:
		case 12:
			txt_Damage[textOrder - 1].MoveTo(userX/2 + 70, userY/2 - 125);
			break;			
	}
	
	txt_Damage[textOrder - 1].SetText(textDamage);
	txt_Damage[textOrder - 1].Move(0, -100, 1.0f);
	txt_Damage[textOrder - 1].SetAlpha(255);
	txt_Damage[textOrder - 1].SetAlpha(0, 1.0f);	
	Me.SetTimer(MIDDLE_TEXT_TIMERID + textOrder, 400);

}


function ShowMultiplier()
{
	local string DmgNum;
	local int resultCount;
	
	resultCount = targetCount - otherCount;
	
	if (resultCount > 1 && showMult)
	{		
		if (isAttackingDmg)
		{
			if (WeapType != 4)
				DmgNum = "";
			else	
				DmgNum="x" $ resultCount $ " ";	
		}
		else
			DmgNum="x" $ resultCount $ " ";	

		if (Len(DmgNum) > 0)
		{
			txt_Multiplier.SetText(DmgNum);
			txt_Multiplier.SetAlpha(255);
			txt_Multiplier.SetAlpha(0, 1.3f);
		}
	}	
}

function OnTimer(int TimerID)
{
	local int currentTextBlock;		// 1-4 or 4-8 textbox
	
	switch (TimerID)
	{	
		case REFRESH_TARGETS_NUMBER_TIMERID:
			ShowMultiplier();
			targetCount = 0;
			otherCount = 0;
			isCrit = false;
			Me.KillTimer(REFRESH_TARGETS_NUMBER_TIMERID);
			break;

		case START_1_TEXT_TIMERID:
		case START_2_TEXT_TIMERID:
		case START_3_TEXT_TIMERID:
		case START_4_TEXT_TIMERID:
			Me.KillTimer(TimerID);
			if (freeTextPosition[TimerID - 1001] == 1)
			{
				currentTextBlock = 0;
				freeTextPosition[TimerID - 1001] = 0;
			}
			else
			{
				if (freeTextPosition[TimerID - 1001 + 4] == 1)
				{
					currentTextBlock = 4;
					freeTextPosition[TimerID - 1001 + 4] = 0;
				}
				else
				{
					currentTextBlock = 8;
				}
			
			}
			ShowOnScreenDamage(damageString[TimerID - 1001], TimerID - 1000 + currentTextBlock, colorString[TimerID - 1001]);
			break;
		
		case MIDDLE_1_TEXT_TIMERID:
		case MIDDLE_2_TEXT_TIMERID:
		case MIDDLE_3_TEXT_TIMERID:
		case MIDDLE_4_TEXT_TIMERID:
		case MIDDLE_5_TEXT_TIMERID:
		case MIDDLE_6_TEXT_TIMERID:
		case MIDDLE_7_TEXT_TIMERID:
		case MIDDLE_8_TEXT_TIMERID:

			Me.KillTimer(TimerID);	
			Me.SetTimer(TimerID + 1000, 400);
			txt_Damage[TimerID - MIDDLE_TEXT_TIMERID - 1].SetAlpha(0, 0.5f);
			txt_Damage[TimerID - MIDDLE_TEXT_TIMERID - 1].Move(0, -100, 0.4f);					
			break;
			
		case MIDDLE_9_TEXT_TIMERID:
		case MIDDLE_10_TEXT_TIMERID:
		case MIDDLE_11_TEXT_TIMERID:
		case MIDDLE_12_TEXT_TIMERID:
			Me.KillTimer(TimerID);	
			txt_Damage[TimerID - MIDDLE_TEXT_TIMERID - 1].SetAlpha(0, 0.5f);
			txt_Damage[TimerID - MIDDLE_TEXT_TIMERID - 1].Move(0, -100, 0.4f);					
			break;
			
		case FINISH_1_TEXT_TIMERID:
		case FINISH_2_TEXT_TIMERID:
		case FINISH_3_TEXT_TIMERID:
		case FINISH_4_TEXT_TIMERID:
		case FINISH_5_TEXT_TIMERID:
		case FINISH_6_TEXT_TIMERID:
		case FINISH_7_TEXT_TIMERID:
		case FINISH_8_TEXT_TIMERID:
			Me.KillTimer(TimerID);
			freeTextPosition[TimerID - 3001] = 1;
			break;
	}
}

function HandleSystemMessage (string a_Param)
{
	local int summonDamage;
	local int playerDamage;
	local int SystemMsgIndex;
  
	ParseInt(a_Param,"Index",SystemMsgIndex);
  
	switch (SystemMsgIndex)
	{
		///////////////////////// crit message
		case 1280:
		case 2266:
			if (targetCount < 5)
				isCrit = true;
			break;
		
		case 2261:		///////////////////////// single hit
		case 2281:		///////////////////////// transfer paint hit
		case 2265:		///////////////////////// evaded hit message
		case 1996:		///////////////////////// blocked hit message
		case 139:		///////////////////////// resist message
		
			if (targetCount == 0)
			{
				Me.SetTimer(REFRESH_TARGETS_NUMBER_TIMERID, 300);		
			}				
			
			if (SystemMsgIndex == 2261 || SystemMsgIndex == 2281)
				ParseInt(a_Param,"Param3", playerDamage);
			
			if ((playerDamage > reflectFilter) || SystemMsgIndex == 1996 || SystemMsgIndex == 2265 || SystemMsgIndex == 139)
			{
				targetCount++;
				if (targetCount < 5)
				{
					messagePosition++;
					if (messagePosition > 3) messagePosition = 0;
					
					switch (SystemMsgIndex)
					{
						case 2261:
							damageString[messagePosition] = string(playerDamage);
							if (isCrit)
							{
								colorString[messagePosition] = 1;
								isCrit = false;
							}
							else
							{
								colorString[messagePosition] = 0;	
							}
							break;
						
						case 2281:
							ParseInt(a_Param,"Param4", summonDamage);
							damageString[messagePosition] = string(playerDamage) $  " + "  $ string(summonDamage);
							if (isCrit)
							{
								colorString[messagePosition] = 1;
								isCrit = false;
							}
							else
							{
								colorString[messagePosition] = 0;	
							}
							break;
							
						case 1996:
							damageString[messagePosition] = "Blocked";
							colorString[messagePosition] = 2;
							break;
							
						case 2265:
							damageString[messagePosition] = "Evaded";
							colorString[messagePosition] = 2;
							break;

						case 139:
							damageString[messagePosition] = "Resisted";
							colorString[messagePosition] = 2;
							break;
					}
					Me.SetTimer(START_1_TEXT_TIMERID + messagePosition, 100);
				}
				
				if (SystemMsgIndex == 1996 || SystemMsgIndex == 2265 || SystemMsgIndex == 139) otherCount++;
			}
			break;
	}
}
defaultproperties
{
}

 

  • 1 month later...

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • Recommended seller, I'm using his services. Good luck @Ave
    • https://l2.gamedream.pl/ Update #2 — GameDream Interlude (C6)     This update focuses on Epic bosses, quest chains and overall QoL :cool Highlights: Frintezza access follows a full retail-like chain: Four Goblets → Last Imperial Prince → Journey to a Settlement Retail-like entry requirements restored (scroll + Command Channel) Four Goblets quest is now available in-game Shot visuals synced with attack/skill usage Community Board Premium Shop refreshed with classic Interlude buttons and cleaner tables Epic Raidboss access: Frintezza — 4–5 party Command Channel + scroll + Antique Brooch Antharas — Portal Stone Baium — Bloody Fabric Valakas — Floating Stone Queen Ant / Core / Orfen / Zaken — no quest gates Bug Fixes & QoL: Frintezza quest chain fully fixed TvT rewards — single reward + anti-abuse protection Shots — no double triggering Premium Shop — no blank tabs Mammon NPCs in Giran working correctly Cancel works retail-like (up to 5 buffs removed) Summon Friend fixed with anti-exploit guards YetiBuffer — Saved Buff Profiles (Save / Clear / Restore) PvE — increased aggro range + balance tweaks EXP toggle commands: expoff / expon / expblock Thanks for testing and feedback — more updates coming soon ❤️
    • Hello I would like to offer You my NEW 2026 Updater / Launcher with custom skins.   - UPDATER FEATURES -   1. Performance and Intelligent Resource Management: Smart Disk Detection (SSD/HDD): The updater automatically detects the user's drive type. For SSD/NVMe drives: Launches up to 8-12 concurrent threads, utilizing the full yet optimized connection speed. For HDD drives: Limits the thread count (to 2-3) to prevent computer slowdowns and avoid overloading the drive head. Multi-threaded Downloading: Instead of downloading file by file, the updater downloads multiple files simultaneously, drastically reducing update time. ZSTD Compression: Support for the modern Zstandard compression algorithm (.zst). Files are downloaded in compressed form and decompressed on the fly, saving bandwidth and accelerating downloads. HTTP/2 and Keep-Alive Support: Utilizing the HTTP/2 protocol and persistent connections allows for the instant download of thousands of small files without establishing a new connection for each one.   2. Modern User Interface (UI/UX): Transparency and PNG Graphics: Support for irregular window shapes, allowing for the creation of a unique, modern launcher look. Taskbar Integration: The progress bar is displayed not only in the window but also on the Windows taskbar icon. Built-in News Browser (Optional): The updater features a built-in browser module that displays news/changelogs directly within the launcher (without opening an external browser). Multi-language Support (Optional): Built-in language switching system (e.g., EN/PL/RU, etc.) with dynamic loading of button graphics and text. Animated Buttons (Optional): Dedicated, animated buttons redirecting to Discord, Facebook, YouTube, Instagram, and the website.   3. Technical Features and Application Security: Anti-Dual Run (Optional): The updater checks if the game is already running to prevent file conflicts during updates. Error Diagnostics: Built-in logging system (debug_log.txt) and hardware exception handling (SEH), facilitating the diagnosis of problems for players who cannot run the game. Internal Configuration: Updater settings are stored inside the .exe file, eliminating publicly accessible configuration files.   4. File Categorization (Normal vs. Critical vs. Once): Critical Files: Critical files are verified more thoroughly (via MD5 Hash) even in quick check mode to guarantee stability. Normal Files: Standard game files (textures, models, sounds) are checked depending on the selected mode (Quick vs. Full). Once Files (Overwrite Exclusions): Applies to user configuration files (e.g., Option.ini, User.ini).   5. Check Modes (Verification Algorithms): Self-Update: The updater can update itself before checking game files, allowing for easy deployment of launcher fixes. The updater supports two main operating modes that switch intelligently based on user action: Smart Check (Startup Quick Check): Runs automatically upon updater startup or pressing the START button (unless a full check is forced). Full Check (Full MD5 Verification): Manually triggered by the player via the "Full Check" button. Automatic Update Detection: If a newer version of a file appears on the server, it is automatically detected and downloaded without player interaction. Atomic Updates: Files are downloaded and verified first, and only then saved to the disk. This prevents game client corruption in case of internet connection loss. The entire process takes seconds, even with clients weighing 30GB+. - PATCH BUILDER FEATURES -   1. Professional File Structure Management (Tree-List Hybrid): Directory Tree Visualization: Instead of a flat file list, the Builder displays a clear structure of folders and subfolders. You can collapse and expand entire tree branches, facilitating work with thousands of files. Normal and Critical Division: A clear window division into two main zones: Normal Files and Critical Files. Ghost and Excluded Files Division: The interface visually informs about the status of unchanged files (existing in the previous patch version) and files excluded from the update. Show/Hide Ghosts: With one click, you can hide unchanged files to focus solely on what you are actually sending to players in this update.   2. Intuitive Interaction: Drag & Drop: Full Drag & Drop support. You can grab files or entire folders and drag them between the "Normal" and "Critical" lists. Transfer is intelligent – it moves the entire content of selected folders. Keyboard Shortcuts: Fast workflow thanks to keyboard support: Delete, Enter, Ctrl+A / Ctrl+C (select and copy paths).   3. Advanced Filtering and Searching: Context Search: The search bar works in real-time, filtering the file tree. Type /folder: Searches only within folder names. Type *ex: Shows only excluded files. Standard Typing: Searches files by name.   4. Automation and Security: Auto Self-Update: The Builder automatically detects the updater executable file. Real-Time Statistics: The status bar continuously shows the file count (Normal/Critical), total patch weight (in Bytes/MB/GB), and the last update date. System File Protection: Files marked as "Critical" cannot be accidentally added to the exclusion list – the program blocks such actions.   5. Performance (Backend): ZSTD Compression: The Builder uses the latest Zstandard algorithm to compress files before sending, ensuring a significantly smaller patch size than standard ZIP, saving server bandwidth and player time. Multi-threading: The packing and MD5 checksum generation process utilizes multiple CPU threads, drastically reducing patch building time.   - PRICING - NEW Updater standard price: 79 euro (if You ask for mods, price will change).   - CONTACT - Discord: ave7309   CLICK HERE TO CHECK LATEST TEMPLATES!                         * I have right to REFUSE to take an order. * Supported games: Lineage 2 / Black Desert / MU Online / Tantra / Rohan / Aion / Cabal / Fiesta any more...  
    • 🔥 Upgrade Your Server's Visual Identity 🔥 Hello Community! We are proud to present the Shadowbane Collection – a premium, oriental-style visual suite designed specifically for Metin2 and Silkroad private servers. Forget about static, boring pages. Give your players a true "AAA" experience with a fully animated video header and a professional brand identity. 🎥 VIDEO PREVIEW   🐉 1. Shadowbane – Animated HTML Website Template A fully coded, responsive website template with a stunning video background. No coding skills required – just upload and configure! 🚀 Technology: HTML5 / CSS3 / JS (No PSD, ready code) 🎥 Animated Header: Loopable video background included (.mp4) 📱 Responsive: Works perfectly on Mobile & Desktop 📂 Pages Included: Home, Rankings, Register, Download, News 👉 DOWNLOAD WEBSITE TEMPLATE HERE       ⚔️ 2. Shadowbane – Game Logo & Text Effect Complete your branding with this matching Logo Template. It works as a Photoshop Text Effect – just type your server name! 🎨 Style: Oriental Gold & Brush Ink ⚡ Easy Edit: Smart Objects (One-click change) 🎁 Bonus: Social Media Kit included (Banner + Avatar) 👉 DOWNLOAD LOGO TEMPLATE HERE 🎁 SPECIAL LAUNCH DISCOUNT 🎁 For forum members, we have prepared a special code. Get 20% OFF on your entire order! CODE: LOVEM2 Elevate your server today with Pixarts.store  
    • Contact me on discord have an offer for you. l2avalon.net  
  • Topics

×
×
  • Create New...

Important Information

This community uses essential cookies to function properly. Non-essential cookies and third-party services are used only with your consent. Read our Privacy Policy and We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue..