require(GlobalDependencys:GetDependency("StandardBase"):GetPackageName()) --GAME VARS fDefaultFOV = 85 fAdditionalFOV = 0 fAspectRatio = DisplayInfo:GetWidth() / DisplayInfo:GetHeight() fDefaultAspectRatio = 1.777777791 fFactor = 0.00872665 --ControlVars bFixEnabled = true bFOV = true bAspect = true bDOF = true bLensDistortion = true bLensSoftness = true bFringe = true bFilmGrain = true --PROCESS VARS Process_FriendlyName = Module:GetFriendlyName() Process_WindowName = "*" Process_ClassName = "UnrealWindow" Process_EXEName = "Hellblade2-Win64-Shipping.exe" --INJECTION BEHAVIOUR InjectDelay = 500 WriteInterval = 100 SearchInterval = 100 SuspendThread = true --Name Manual/Auto/Hybrid Steam/Origin/Any IncludeFile:Configure;Enable;Periodic;Disable; SupportedVersions = { {"Automatically Detect", "Hybrid", "Any", "Configure_SignatureScan;Enable_Inject;Periodic;Disable_Inject;"}, } function Init_Controls() DefaultControls.AddHeader("Header_FixesEnableDisable","Individual Fixes",245,70,210,17) DefaultControls.AddHeader("Header_FOV","In game FOV fine adjustment",15,70,210,17) DefaultControls.AddFixedFOVSlider("FOVSlider","FOVSlider_Changed",55,100,125,35,0,70,0,1) FOVSlider:SetTickFrequency(10) FOVSlider:SetLabel1Text("-20") FOVSlider:SetLabel2Text("+50") DefaultControls.AddFixToggle("CKFOVFix_Enable","FOV fix","CKFOVFix_Changed",255,101,180,14) DefaultControls.AddFixToggle("CKARFix_Enable","Aspect ratio fix","CKARFix_Changed",255,121,180,14) DefaultControls.AddFixToggle("CKDOFFix_Enable","Depth of field fix","CKDOFFix_Changed",255,141,180,14) DefaultControls.AddFixToggle("CKLENSDISTORTIONFix_Enable","Lens distortion fix","CKLENSDISTORTIONFix_Changed",255,161,180,14) DefaultControls.AddFixToggle("CKLENSSOFTNESSFix_Enable","Lens softness fix","CKLENSSOFTNESSFix_Changed",255,181,180,14) DefaultControls.AddFixToggle("CKFRINGEFix_Enable","Chromatic aberrations fix","CKFRINGEFix_Changed",255,201,180,14) DefaultControls.AddFixToggle("CKFILMGRAINFix_Enable","Film grain fix","CKFILMGRAINFix_Changed",255,221,180,14) end function Configure_SignatureScan() print ("test") local tAddress = HackTool:AddAddress("FOV") if HackTool:SignatureScan("48 ?? ?? FF 90 ?? ?? ?? ?? F3 0F ?? ?? ?? 48 ?? ?? 48 ?? ?? 4C",tAddress,PAGE_EXECUTE_READ,0x09,Process_EXEName) == 0 then return ErrorOccurred(string.format(SigScanError,tAddress:GetName())) else print( tAddress:GetInfo(TYPE_ADDRESS) ) --Hellblade2-Win64-Shipping.exe+3451CA4 - 48 8B 01 - mov rax,[rcx] --Hellblade2-Win64-Shipping.exe+3451CA7 - FF 90 58 07 00 00 - call qword ptr [rax+00000758] --Hellblade2-Win64-Shipping.exe+3451CAD - F3 0F 10 40 30 - movss xmm0,[rax+30] --Hellblade2-Win64-Shipping.exe+3451CB2 - 48 83 C4 28 - add rsp,28 --Hellblade2-Win64-Shipping.exe+3451CB6 - C3 - ret end local tResultCount = HackTool:SignatureScanMulti("48 89 ?? ?? ?? 57 48 83 ?? ?? 0F ?? ?? 48 8B ?? 48 8B FA 0F ?? ?? F2 0F ?? ?? ?? F2 0F ?? ?? ??","ASPECTS",PAGE_EXECUTE_READ,0x59,Process_EXEName) if tResultCount ~= 3 then return ErrorOccurred("Could not find ASPECTS injection point, " .. Process_FriendlyName .. " may have updated to a version that is no longer supported.\r\n\r\n" .. "Try selecting a different version and re-enable the fix." ) else local tAddress = HackTool:AddAddress("ASPECT", HackTool:GetAddress( string.format("ASPECTS%d",1) )) print( tAddress:GetInfo(TYPE_ADDRESS) ) --Hellblade2-Win64-Shipping.exe+2C63563 - 89 41 44 - mov [rcx+44],eax --Hellblade2-Win64-Shipping.exe+2C63566 - 8B 42 48 - mov eax,[rdx+48] --Hellblade2-Win64-Shipping.exe+2C63569 - 89 41 48 - mov [rcx+48],eax --Hellblade2-Win64-Shipping.exe+2C6356C - 48 8D 42 4C - lea rax,[rdx+4C] --Hellblade2-Win64-Shipping.exe+2C63570 - 48 83 C1 4C - add rcx,4C end local tAddress = HackTool:AddAddress("DOF") if HackTool:SignatureScan("75 ?? BF ?? ?? ?? ?? 8B ?? ?? 48 ?? ?? E8",tAddress,PAGE_EXECUTE_READ,0x07,Process_EXEName) == 0 then return ErrorOccurred(string.format(SigScanError,tAddress:GetName())) else print( tAddress:GetInfo(TYPE_ADDRESS) ) --Hellblade2-Win64-Shipping.exe+1FD54C3 - 75 05 - jne Hellblade2-Win64-Shipping.exe+1FD54CA --Hellblade2-Win64-Shipping.exe+1FD54C5 - BF 04 00 00 00 - mov edi,00000004 --Hellblade2-Win64-Shipping.exe+1FD54CA - 8B 3C 37 - mov edi,[rdi+rsi] --Hellblade2-Win64-Shipping.exe+1FD54CD - 48 8B CB - mov rcx,rbx --Hellblade2-Win64-Shipping.exe+1FD54D0 - E8 2B 05 55 01 - call Hellblade2-Win64-Shipping.exe+3525A00 end local tAddress = HackTool:AddAddress("LENSDISTORTION") if HackTool:SignatureScan("F3 0F ?? ?? ?? F3 41 0F ?? ?? ?? ?? ?? ?? 49 8B ?? ?? ?? ?? ?? 48",tAddress,PAGE_EXECUTE_READ,0x0,Process_EXEName) == 0 then return ErrorOccurred(string.format(SigScanError,tAddress:GetName())) else print( tAddress:GetInfo(TYPE_ADDRESS) ) --Hellblade2-Win64-Shipping.exe+200F2AF - 48 8B 05 D2 8A 89 08 - mov rax,[Hellblade2-Win64-Shipping.exe+A8A7D88] --Hellblade2-Win64-Shipping.exe+200F2B6 - F3 41 0F 10 85 60 22 00 00 - movss xmm0,[r13+00002260] --Hellblade2-Win64-Shipping.exe+200F2BF - F3 0F 59 40 04 - mulss xmm0,[rax+04] --Hellblade2-Win64-Shipping.exe+200F2C4 - F3 41 0F 11 87 B8 00 00 00 - movss [r15+000000B8],xmm0 --Hellblade2-Win64-Shipping.exe+200F2CD - 49 8B 8D 70 22 00 00 - mov rcx,[r13+00002270] end local tAddress = HackTool:AddAddress("LENSSOFTNESS") if HackTool:SignatureScan("F3 0F ?? ?? ?? 8D ?? ?? ?? ?? F3 41 0F ?? ?? ?? ?? ?? ?? 41",tAddress,PAGE_EXECUTE_READ,0x0,Process_EXEName) == 0 then return ErrorOccurred(string.format(SigScanError,tAddress:GetName())) else print( tAddress:GetInfo(TYPE_ADDRESS) ) --Hellblade2-Win64-Shipping.exe+200E3ED - F3 41 0F 10 86 18 23 00 00 - movss xmm0,[r14+00002318] --Hellblade2-Win64-Shipping.exe+200E3F6 - 8B B5 18 01 00 00 - mov esi,[rbp+00000118] --Hellblade2-Win64-Shipping.exe+200E3FC - F3 0F 59 40 04 - mulss xmm0,[rax+04] --Hellblade2-Win64-Shipping.exe+200E401 - 8D 1C 73 - lea ebx,[rbx+rsi*2] --Hellblade2-Win64-Shipping.exe+200E404 - 03 DE - add ebx,esi end local tAddress = HackTool:AddAddress("FRINGE") if HackTool:SignatureScan("F3 0F ?? ?? ?? F3 41 0F ?? ?? ?? ?? ?? ?? 48 8B ?? ?? ?? ?? ?? E8",tAddress,PAGE_EXECUTE_READ,0x0,Process_EXEName) == 0 then return ErrorOccurred(string.format(SigScanError,tAddress:GetName())) else print( tAddress:GetInfo(TYPE_ADDRESS) ) --Hellblade2-Win64-Shipping.exe+200D974 - 48 8B 05 F5 A3 89 08 - mov rax,[Hellblade2-Win64-Shipping.exe+A8A7D70] --Hellblade2-Win64-Shipping.exe+200D97B - F3 0F 10 86 E8 22 00 00 - movss xmm0,[rsi+000022E8] --Hellblade2-Win64-Shipping.exe+200D983 - F3 0F 59 40 04 - mulss xmm0,[rax+04] --Hellblade2-Win64-Shipping.exe+200D988 - F3 41 0F 11 87 D8 00 00 00 - movss [r15+000000D8],xmm0 --Hellblade2-Win64-Shipping.exe+200D991 - 48 8B 9E 28 C2 00 00 - mov rbx,[rsi+0000C228] end local tAddress = HackTool:AddAddress("FILMGRAIN") if HackTool:SignatureScan("0F 84 ?? ?? ?? ?? 49 ?? ?? E8 ?? ?? ?? ?? 48 ?? ?? 48 8D ?? ?? ?? ?? ?? 0F B7",tAddress,PAGE_EXECUTE_READ,0x0,Process_EXEName) == 0 then return ErrorOccurred(string.format(SigScanError,tAddress:GetName())) else print( tAddress:GetInfo(TYPE_ADDRESS) ) --Hellblade2-Win64-Shipping.exe+218DA65 - 48 8B 05 E4 E9 74 08 - mov rax,[Hellblade2-Win64-Shipping.exe+A8DC450] --Hellblade2-Win64-Shipping.exe+218DA6C - 83 38 00 - cmp dword ptr [rax],00 --Hellblade2-Win64-Shipping.exe+218DA6F - 0F 84 BF 00 00 00 - je Hellblade2-Win64-Shipping.exe+218DB34 --Hellblade2-Win64-Shipping.exe+218DA75 - 49 8B CC - mov rcx,r12 --Hellblade2-Win64-Shipping.exe+218DA78 - E8 53 6D 39 01 - call Hellblade2-Win64-Shipping.exe+35247D0 end return true end function Enable_Inject() local Variables = HackTool:AllocateMemory("Variables",0) Variables:PushFloat("CompensatedFOV") Variables:PushFloat("FOVIn") Variables:PushFloat("FOVOut") Variables:PushFloat("AdditionalFOV") Variables:PushFloat("AspectRatio") Variables:PushFloat("ScreenRatio") Variables:PushFloat("factor") Variables:PushInt("Aspect") Variables:Allocate() Variables["FOVIn"]:WriteFloat(fDefaultFOV) Variables["FOVOut"]:WriteFloat(fDefaultFOV) Variables["AdditionalFOV"]:WriteFloat(fAdditionalFOV) Variables["AspectRatio"]:WriteFloat(fDefaultAspectRatio) Variables["ScreenRatio"]:WriteFloat(fAspectRatio) Variables["factor"]:WriteFloat(fFactor) ResolutionChanged() local asm = [[ (codecave:jmp)FOV,FOV_cc: $$0 [(allocation)Variables->FOVIn],$$2 $ctx=1 fld dword ptr [(allocation)Variables->FOVIn] cmp dword ptr [(allocation)Variables->Aspect],1 jne regularFOV fmul dword ptr [(allocation)Variables->factor] fptan fstp st0 fld dword ptr [(allocation)Variables->ScreenRatio] fdiv dword ptr [(allocation)Variables->AspectRatio] fmulp st1,st0 fld1 fpatan fdiv dword ptr [(allocation)Variables->factor] fst dword ptr [(allocation)Variables->CompensatedFOV] regularFOV: fadd dword ptr [(allocation)Variables->AdditionalFOV] fstp dword ptr [(allocation)Variables->FOVOut] $$0 $$2,[(allocation)Variables->FOVOut] $ctx=1 %originalcode% jmp %returnaddress% %end% (codecave:jmp)ASPECT,ASPECT_cc: $$0 $$2,[(allocation)Variables->ScreenRatio] $ctx=1 %originalcode% jmp %returnaddress% %end% (codecave)DOF,DOF_cc: xor $$1,$$1 $ctx=1 nop %end% (codecave)LENSDISTORTION,LENSDISTORTION_cc: xorps $$1,$$1 $ctx=1 nop nop %end% (codecave)LENSSOFTNESS,LENSSOFTNESS_cc: xorps $$1,$$1 $ctx=1 nop nop %end% (codecave)FRINGE,FRINGE_cc: xorps $$1,$$1 $ctx=1 nop nop %end% (codecave)FILMGRAIN,FILMGRAIN_cc: jmp $$1 nop ]] if HackTool:CompileAssembly(asm,"Fixes") == nil then return ErrorOccurred("Assembly compilation failed...") else Toggle_CodeCave("FOV_cc",bFOV) Toggle_CodeCave("ASPECT_cc",bAspect) Toggle_CodeCave("DOF_cc",bDOF) Toggle_CodeCave("LENSDISTORTION_cc",bLensDistortion) Toggle_CodeCave("LENSSOFTNESS_cc",bLensSoftness) Toggle_CodeCave("FRINGE_cc",bFringe) Toggle_CodeCave("FILMGRAIN_cc",bFilmGrain) end Write_FOV() Write_AspectRatio() end function Periodic() local Variables = HackTool:GetAllocation("Variables") if Variables and Variables["FOVIn"] and Variables["AdditionalFOV"] then local fCompensatedFOV = Variables["CompensatedFOV"]:ReadFloat() local fFOVIn = Variables["FOVIn"]:ReadFloat() local fFOVOut = Variables["FOVOut"]:ReadFloat() PluginViewport:AppendStatusMessage( string.format("\r\n===== Fix informations =====\r\nFOV In: %0.2f, Compensated FOV : %0.2f, FOV Out : %.02f", fFOVIn, fCompensatedFOV, fFOVOut)) end end function FOVSlider_Changed(Sender) fAdditionalFOV = Sender:GetPosition() - 20 lblFOVSlider.Caption:SetCaption( string.format("Value: %.0f",fAdditionalFOV) ) Write_FOV() ForceUpdate() end function Write_FOV() local Variables = HackTool:GetAllocation("Variables") if Variables and Variables["AdditionalFOV"] then if bFOV == true then Variables["AdditionalFOV"]:WriteFloat(fAdditionalFOV) else Variables["AdditionalFOV"]:WriteFloat(0) end end end function Write_AspectRatio() local Variables = HackTool:GetAllocation("Variables") if Variables and Variables["AspectRatio"] and Variables["CompensatedFOV"] and Variables["FOVIn"] then if bAspect == false then local fFOVIn = Variables["FOVIn"]:ReadFloat() Variables["CompensatedFOV"]:WriteFloat(fFOVIn) Variables["Aspect"]:WriteInt(0) else Variables["Aspect"]:WriteInt(1) end end end function Disable_Inject() CleanUp() end function CKFOVFix_Changed(Sender) bFOV = Toggle_CheckFix(Sender) Write_FOV() Toggle_CodeCave("FOV_cc",bFOV) ForceUpdate() end function CKARFix_Changed(Sender) bAspect = Toggle_CheckFix(Sender) Write_AspectRatio() Toggle_CodeCave("ASPECT_cc",bAspect) ForceUpdate() end function CKDOFFix_Changed(Sender) bDOF = Toggle_CheckFix(Sender) Toggle_CodeCave("DOF_cc",bDOF) ForceUpdate() end function CKLENSDISTORTIONFix_Changed(Sender) bLensDistortion = Toggle_CheckFix(Sender) Toggle_CodeCave("LENSDISTORTION_cc",bLensDistortion) ForceUpdate() end function CKLENSSOFTNESSFix_Changed(Sender) bLensSoftness = Toggle_CheckFix(Sender) Toggle_CodeCave("LENSSOFTNESS_cc",bLensSoftness) ForceUpdate() end function CKFRINGEFix_Changed(Sender) bFringe = Toggle_CheckFix(Sender) Toggle_CodeCave("FRINGE_cc",bFringe) ForceUpdate() end function CKFILMGRAINFix_Changed(Sender) bFilmGrain = Toggle_CheckFix(Sender) Toggle_CodeCave("FILMGRAIN_cc",bFilmGrain) ForceUpdate() end function ResolutionChanged() SyncDisplayDetection() end function Init() Init_BaseControls() Init_Controls() end function DeInit() DisableFix() end