View previous topic :: View next topic |
Author |
Message |
Ejay1984 Newbie cheater
Reputation: 0
Joined: 16 Nov 2017 Posts: 24
|
Posted: Thu Nov 16, 2017 1:37 pm Post subject: I need help with an Auto Assemble Script |
|
|
Hi,
I'm new to Cheat Engine and I've been working my way through tutorials and the like. I am trying to create a cheat for infinite health on the latest version of Shovel Knight. I am currently in the process of creating the script but I'm not sure what command to use to effect the change.
The script is as follows;
Code: | [ENABLE]
//code from here to '[DISABLE]' will be used to enable the cheat
alloc(newmem,2048)
label(returnhere)
label(originalcode)
label(exit)
newmem: //this is allocated memory, you have read,write,execute access
//place your code here
originalcode:
fld dword ptr [edx]
fnstcw [esp+16]
exit:
jmp returnhere
"ShovelKnight.exe"+1D0C5B:
jmp newmem
nop
returnhere:
[DISABLE]
//code from here till the end of the code will be used to disable the cheat
dealloc(newmem)
"ShovelKnight.exe"+1D0C5B:
fld dword ptr [edx]
fnstcw [esp+16]
//Alt: db D9 02 D9 7C 24 16
|
I would be extremely grateful for any help.
Cheers
|
|
Back to top |
|
 |
OldCheatEngineUser Whateven rank
Reputation: 20
Joined: 01 Feb 2016 Posts: 1586
|
Posted: Thu Nov 16, 2017 4:44 pm Post subject: |
|
|
fld dword ptr [edx]
first make sure the above instruction does not access any other object except player health by right-clicking the instruction and choosing "find out what addresses this instruction accesses" then you can process.
_________________
About Me;
I Use CE Since Version 1.X, And Still Learning How To Use It Well!
Jul 26, 2020
STN wrote: | i am a sweetheart. |
|
|
Back to top |
|
 |
Ejay1984 Newbie cheater
Reputation: 0
Joined: 16 Nov 2017 Posts: 24
|
Posted: Fri Nov 17, 2017 12:58 am Post subject: |
|
|
OldCheatEngineUser wrote: | fld dword ptr [edx]
first make sure the above instruction does not access any other object except player health by right-clicking the instruction and choosing "find out what addresses this instruction accesses" then you can process. |
Thanks a lot. Do I need to alter the existing instruction or replace it with a new instruction?
I had previously put the // symbol in front of the instruction but it drained my players energy whilst leaving the player alive. The instruction was one of three that only affected my player.
The others were;
fcom dword ptr [edx]
fcomp dword ptr [edx]
|
|
Back to top |
|
 |
Prehistoricman Advanced Cheater
Reputation: 0
Joined: 02 Aug 2016 Posts: 80
|
Posted: Fri Nov 17, 2017 2:19 am Post subject: |
|
|
What instructions exist after the fcom and fcomp? They might be checking if you're supposed to be dead.
Try putting this before the fld in your AA script:
mov [eax], (float)100
Where 100 is the health you want to have.
_________________
Er, hi |
|
Back to top |
|
 |
Ejay1984 Newbie cheater
Reputation: 0
Joined: 16 Nov 2017 Posts: 24
|
Posted: Fri Nov 17, 2017 2:36 am Post subject: |
|
|
Prehistoricman wrote: | What instructions exist after the fcom and fcomp? They might be checking if you're supposed to be dead.
Try putting this before the fld in your AA script:
mov [eax], (float)100
Where 100 is the health you want to have. |
Hi,
They are;
fld dword ptr [edx]
fnstcw [esp+16]
fcom dword ptr [edx]
fnstsw ax
fcomp dword ptr [edx]
fnstsw ax
|
|
Back to top |
|
 |
OldCheatEngineUser Whateven rank
Reputation: 20
Joined: 01 Feb 2016 Posts: 1586
|
Posted: Fri Nov 17, 2017 4:48 am Post subject: |
|
|
i can guess that you found:
Code: | fld dword ptr [edx] |
by choosing "find out whats accesses this address" correct me im wrong.
which means this instruction is accessing your health address many time per second.
this might not be very effective as a health cheat or god mode, but you can do it this way:
Code: | [ENABLE]
//code from here to '[DISABLE]' will be used to enable the cheat
alloc(newmem,2048)
label(returnhere)
label(originalcode)
label(exit)
label(maxhealth)
newmem: //this is allocated memory, you have read,write,execute access
//place your code here
fld dword ptr [maxhealth]
fstp dword ptr [edx]
originalcode:
fld dword ptr [edx]
fnstcw [esp+16]
maxhealth:
dd (float)100.00 // change this number to whatever your max health is
exit:
jmp returnhere
"ShovelKnight.exe"+1D0C5B:
jmp newmem
nop
returnhere:
[DISABLE]
//code from here till the end of the code will be used to disable the cheat
dealloc(newmem)
"ShovelKnight.exe"+1D0C5B:
fld dword ptr [edx]
fnstcw [esp+16]
//Alt: db D9 02 D9 7C 24 16 |
_________________
About Me;
I Use CE Since Version 1.X, And Still Learning How To Use It Well!
Jul 26, 2020
STN wrote: | i am a sweetheart. |
|
|
Back to top |
|
 |
Ejay1984 Newbie cheater
Reputation: 0
Joined: 16 Nov 2017 Posts: 24
|
Posted: Fri Nov 17, 2017 5:56 am Post subject: |
|
|
OldCheatEngineUser wrote: | i can guess that you found:
Code: | fld dword ptr [edx] |
by choosing "find out whats accesses this address" correct me im wrong.
which means this instruction is accessing your health address many time per second.
this might not be very effective as a health cheat or god mode, but you can do it this way:
Code: | [ENABLE]
//code from here to '[DISABLE]' will be used to enable the cheat
alloc(newmem,2048)
label(returnhere)
label(originalcode)
label(exit)
label(maxhealth)
newmem: //this is allocated memory, you have read,write,execute access
//place your code here
fld dword ptr [maxhealth]
fstp dword ptr [edx]
originalcode:
fld dword ptr [edx]
fnstcw [esp+16]
maxhealth:
dd (float)100.00 // change this number to whatever your max health is
exit:
jmp returnhere
"ShovelKnight.exe"+1D0C5B:
jmp newmem
nop
returnhere:
[DISABLE]
//code from here till the end of the code will be used to disable the cheat
dealloc(newmem)
"ShovelKnight.exe"+1D0C5B:
fld dword ptr [edx]
fnstcw [esp+16]
//Alt: db D9 02 D9 7C 24 16 |
|
Thanks a lot. I'll try it.
|
|
Back to top |
|
 |
|