• Hello Guest! Welcome to ConsoleCrunch, to help support our site check out the premium upgrades HERE! to get exclusive access to our hidden content.
  • Unable to load portions of the website...
    If you use an ad blocker addon, you should disable it because it interferes with several elements of the site and blocks more than just adverts.
  • Read Rules Before Posting Post Virus Scans with every program.

Basics of C# RTM Tool Coding Tutorial SUPER NOOB FRIENDLY! part 1

Mr1337

Active Poster
Active Member
Hey guys, I've finally thought that I should create a thread about the basics of C# and how to use them into coding a RTM Tool for any game. This is a SUPER NOOB friendly tutorial, meaning people that don't know a thing about C# can learn from this. We will be using the game Call of Duty : Ghosts as a example today. But you can follow my steps and create it for any other game as long as you have the offsets. So lets get started off!

First you will need Visual Studios, you can get any version you want. But if you want to keep up to date get Visual Studios 2013 Ultimate, Click http://www.microsoft.com/en-us/download/details.aspx?id=40778 to download it.



After Visual Studios has downloaded open it up, it should look like this:
Spoiler:

4a351778cec7fc61cac5c6a79328ba31.png



If you're wondering how I got the color of VS to be dark all you have to do is go to Tools, and click "Options"
Example:
Spoiler:
db14fda6a743083714a6bcf0f0e579f8.png


and you should see the very first option is called "Color Theme", there are 3 different ones, look at them all and see which one you like most.

Alright so now back to the coding, click "New Project" on the top left of Visual Studios and a windows like so shall pop up.
Spoiler:
4982f6bd46b1652d3f766ec93ef30984.png


Click on "Windows Form Application" and where it says "Name" you can name it anything you want like My First RTM Tool or Ghosts RTM Tool.

Now you should get a form looking like this:
Spoiler:
713f746315e98b22523fc1a9fd646c9b.png


You can change it's size to whatever you want simply by dragging the little white squares around the Form.

Now you might of seen other people using TMAPI, we're going to be using PS3Lib. It's a shorter version of TMAPI and its compatible with CCAPI. So you're coding will work for DEX users and CEX users. Click HERE to download PS3Lib.Dll

Once you have download PS3Lib.Dll you need to add it as a reference, same goes with other dll's. If you ever wanted to make your program have a nice design you use DevComponents, it's a dll, so you would add it as reference. Remember that you can't add CCAPI.dll as a reference but you do need it in the same folder as your program.

To add it as a reference go to: Project on the top of Visual Studios, click on it. Go down to Add a reference. A box should pop up looking like this:
Spoiler:
image.jpg



Click "Browse" and find the PS3Lib.Dll and add it as a reference.
Now once you have added PS3Lib, double click on the Form and it should look like this:
Spoiler:
450329580438df5eeec51c4f0d7c9f81.png



Where it says "using System; using System.Collections.Generic; and so on, under those. Add "using PS3Lib;" without the quotation marks.

Now under "InitializeComponent();" add this code:
Code:
public static PS3API PS3 = new PS3API();
What this code is doing is declaring the 3 letter word "PS3" as a API. And where it says new PS3API(); If you wanted your tool to be just CCAPI compatible or just DEX compatible you would put either new PS3API(SelectAPI.TargetManager); or new PS3API(SelectAPI.ControlConsole);

So now that we have that out of our way lets go back to the form. The design of your form should be at the top, click Form1.cs[Design]*

Now click on the form once, and you will see a properties windows pop up & and toolbox. If the toolbox isn't there. Go to the top of Visual Studios and click "View" and then click toolbox.

Now drag 2 buttons to the form and size them to however you like. Name one "Connect" and name one "Attach". You can rename them simply by clicking on the button and on the properties windows find "Text" and you can change the text there.
Spoiler:
7ac126ef678bf354fccaedb290164ad9.png



Double click on the "Connect" button or whatever you've named it.
And put the following code:

Code:
try
{
PS3.ConnectTarget(0);
MessageBox.Show("Successfully Connected to Target!", "Connected", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
catch
{
MessageBox.Show("Failed to Connect", "Failed", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
"try" & "catch" is for exception handling meaning that it will try the block of code in the first { } brackets and if it succeeds, in our case if its connects successfully a messagebox will pop up saying we've successfully connected. But if it fails, it will "catch" it, meaning it wont leave the program unresponding. It will catch the error with a messagebox saying it failed.

Now it's same thing for the "Attach" button, use the same code but instead of PS3.ConnectTarget(0); use PS3.AttachProcess();

Your code would look something like this:
Code:
try
{
PS3.AttachProcess();
MessageBox.Show("Successfully Attached to Proccess!", "Attached", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
catch
{
MessageBox.Show("Failed to Attached", "Failed", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
Now before we continue hit the "Save All" button on the top of Visual Studios just in case Visual Studios crashes.
Click the box circled in grey in the following picture:
Spoiler:
22bfd361c39c3ab6a47c3744cfa6530d.png



Ok, now we have to add 2 radio buttons so the user can select weather they want to Connect using "DEX" or "CEX". Go into the toolbox and drag 2 radio buttons and name once "DEX and the other one "CEX". Now double click on "DEX" and add the following code:
Code:
PS3.ChangeAPI(SelectAPI.TargetManager);
And now go back and double click on the "CEX" radio button and add the following code:
Code:
PS3.ChangeAPI(SelectAPI.ControlConsole);
Spoiler:
49e0f9d15c4bbbd8a4e0709d553e7c48.png


You're probably getting a error on the "Control Console" bit because it's saying that PS3Lib doesn't contain "Control Console" that's because you have to add CCAPI.Dll to the debug folder. It won't let you add it as a reference. Download CCAPI.Dll HERE.
Now find where your "Visual Studios" folder is located, mine is in my documents folder. Once you have found it, open it. Click "Projects", find your project. Open it. There should be another folder inside it named the same thing so open that folder. Then open the folder "Bin", then open the folder "Debug" and drag the CCAPI.Dll in the debug folder. If you're still getting the error build the solution so it refreshes. Click "Build" at the top of Visual Studios and click "Build Solution"
Spoiler:
f43f20a5d16bd3e7dfcbc583bec71111.png


What these codes are doing is changing the API or Kernel the user is connecting to, as specified earlier in the thread, we didn't say weather on load our API method will be TargetManager or Control Console. In this code with the 2 radio buttons you can change between target types.



Now add another 2 buttons to the Form and name one "No Recoil ON" & then other one "No Recoil OFF".
You can still follow the tutorial if you have a different offset for lets say red boxes, or chrome players, or anything like that. So these are the No Recoil ON and OFF bytes including the address.
Code:
Red Boxes: 0x14492C (On - 0x60, 0x00, 0x00, 0x00 | Off - 0x41, 0x82,0x00, 0x0c)
Double click the "No Recoil ON" button and put the following code:
Code:
byte[] norecoilon = new byte[] { 0x60, 0x00, 0x00, 0x00 };
PS3.SetMemory(0x14492C, norecoilon);
What you're doing here is declaring a byte named "norecoilon" remember that the name of the byte doesn't really matter, you can name it "34itji43tjj4" because it doesn't really matter. Then the ON bytes for No Recoil are 0x60, 0x00, 0x00, 0x00 so you're putting the bytes into hex format.
Then your setting the memory with the No Recoil address which is 0x14492C, and then beside it your putting the byte norecoilon. So lets conclude this: You've made a byte named norecoilon, that byte has the bytes in hex: 0x60, 0x00, 0x00, 0x00. Then your setting the memory to your PS3 by setting the bytes in "norecoilon" to the offset 0x14492C.

Now you do the same thing for No Recoil OFF but its different bytes. Your code for No Recoil OFF would look like:
Code:
byte[] norecoiloff = new byte[] { 0x41, 0x82,0x00, 0x0c };
PS3.SetMemory(0x14492C, norecoiloff);
Now you're finally finished, all you have to do now is run the .exe. You can debug it meaning if any random error occurs in the code the program will stop or run it without debugging meaning just running it straight from the .exe. To debug all you have to do is click "Start" at the top of Visual Studios or if you want to run it without debugging click the little arrow beside "Start" and it will drop down with another Start feature, click that start.
Spoiler:
fa32edd7a96eda8cb6fc38037c2c5994.png



Now you're finally done, to distribute your file click "Save All" (there was a pic earlier in the thread) and find the Visual Studios 2013 folder. Mine is located in my documents, once you have found it. Click on it, click "Projects" and find the folder with your tool that you've just created. You're tool will be in the debug folder. Remember if you're going to send people the tool remember to send them with the dll's. You can add a lot more non host mods or anything you would like from this offset thread:
 
Hey guys, I've finally thought that I should create a thread about the basics of C# and how to use them into coding a RTM Tool for any game. This is a SUPER NOOB friendly tutorial, meaning people that don't know a thing about C# can learn from this. We will be using the game Call of Duty : Ghosts as a example today. But you can follow my steps and create it for any other game as long as you have the offsets. So lets get started off!

First you will need Visual Studios, you can get any version you want. But if you want to keep up to date get Visual Studios 2013 Ultimate, Click http://www.microsoft.com/en-us/download/details.aspx?id=40778 to download it.



After Visual Studios has downloaded open it up, it should look like this:
Spoiler:

4a351778cec7fc61cac5c6a79328ba31.png



If you're wondering how I got the color of VS to be dark all you have to do is go to Tools, and click "Options"
Example:
Spoiler:
db14fda6a743083714a6bcf0f0e579f8.png


and you should see the very first option is called "Color Theme", there are 3 different ones, look at them all and see which one you like most.

Alright so now back to the coding, click "New Project" on the top left of Visual Studios and a windows like so shall pop up.
Spoiler:
4982f6bd46b1652d3f766ec93ef30984.png


Click on "Windows Form Application" and where it says "Name" you can name it anything you want like My First RTM Tool or Ghosts RTM Tool.

Now you should get a form looking like this:
Spoiler:
713f746315e98b22523fc1a9fd646c9b.png


You can change it's size to whatever you want simply by dragging the little white squares around the Form.

Now you might of seen other people using TMAPI, we're going to be using PS3Lib. It's a shorter version of TMAPI and its compatible with CCAPI. So you're coding will work for DEX users and CEX users. Click HERE to download PS3Lib.Dll

Once you have download PS3Lib.Dll you need to add it as a reference, same goes with other dll's. If you ever wanted to make your program have a nice design you use DevComponents, it's a dll, so you would add it as reference. Remember that you can't add CCAPI.dll as a reference but you do need it in the same folder as your program.

To add it as a reference go to: Project on the top of Visual Studios, click on it. Go down to Add a reference. A box should pop up looking like this:
Spoiler:
image.jpg



Click "Browse" and find the PS3Lib.Dll and add it as a reference.
Now once you have added PS3Lib, double click on the Form and it should look like this:
Spoiler:
450329580438df5eeec51c4f0d7c9f81.png



Where it says "using System; using System.Collections.Generic; and so on, under those. Add "using PS3Lib;" without the quotation marks.

Now under "InitializeComponent();" add this code:
Code:
public static PS3API PS3 = new PS3API();
What this code is doing is declaring the 3 letter word "PS3" as a API. And where it says new PS3API(); If you wanted your tool to be just CCAPI compatible or just DEX compatible you would put either new PS3API(SelectAPI.TargetManager); or new PS3API(SelectAPI.ControlConsole);

So now that we have that out of our way lets go back to the form. The design of your form should be at the top, click Form1.cs[Design]*

Now click on the form once, and you will see a properties windows pop up & and toolbox. If the toolbox isn't there. Go to the top of Visual Studios and click "View" and then click toolbox.

Now drag 2 buttons to the form and size them to however you like. Name one "Connect" and name one "Attach". You can rename them simply by clicking on the button and on the properties windows find "Text" and you can change the text there.
Spoiler:
7ac126ef678bf354fccaedb290164ad9.png



Double click on the "Connect" button or whatever you've named it.
And put the following code:

Code:
try
{
PS3.ConnectTarget(0);
MessageBox.Show("Successfully Connected to Target!", "Connected", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
catch
{
MessageBox.Show("Failed to Connect", "Failed", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
"try" & "catch" is for exception handling meaning that it will try the block of code in the first { } brackets and if it succeeds, in our case if its connects successfully a messagebox will pop up saying we've successfully connected. But if it fails, it will "catch" it, meaning it wont leave the program unresponding. It will catch the error with a messagebox saying it failed.

Now it's same thing for the "Attach" button, use the same code but instead of PS3.ConnectTarget(0); use PS3.AttachProcess();

Your code would look something like this:
Code:
try
{
PS3.AttachProcess();
MessageBox.Show("Successfully Attached to Proccess!", "Attached", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
catch
{
MessageBox.Show("Failed to Attached", "Failed", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
Now before we continue hit the "Save All" button on the top of Visual Studios just in case Visual Studios crashes.
Click the box circled in grey in the following picture:
Spoiler:
22bfd361c39c3ab6a47c3744cfa6530d.png



Ok, now we have to add 2 radio buttons so the user can select weather they want to Connect using "DEX" or "CEX". Go into the toolbox and drag 2 radio buttons and name once "DEX and the other one "CEX". Now double click on "DEX" and add the following code:
Code:
PS3.ChangeAPI(SelectAPI.TargetManager);
And now go back and double click on the "CEX" radio button and add the following code:
Code:
PS3.ChangeAPI(SelectAPI.ControlConsole);
Spoiler:
49e0f9d15c4bbbd8a4e0709d553e7c48.png


You're probably getting a error on the "Control Console" bit because it's saying that PS3Lib doesn't contain "Control Console" that's because you have to add CCAPI.Dll to the debug folder. It won't let you add it as a reference. Download CCAPI.Dll HERE.
Now find where your "Visual Studios" folder is located, mine is in my documents folder. Once you have found it, open it. Click "Projects", find your project. Open it. There should be another folder inside it named the same thing so open that folder. Then open the folder "Bin", then open the folder "Debug" and drag the CCAPI.Dll in the debug folder. If you're still getting the error build the solution so it refreshes. Click "Build" at the top of Visual Studios and click "Build Solution"
Spoiler:
f43f20a5d16bd3e7dfcbc583bec71111.png


What these codes are doing is changing the API or Kernel the user is connecting to, as specified earlier in the thread, we didn't say weather on load our API method will be TargetManager or Control Console. In this code with the 2 radio buttons you can change between target types.



Now add another 2 buttons to the Form and name one "No Recoil ON" & then other one "No Recoil OFF".
You can still follow the tutorial if you have a different offset for lets say red boxes, or chrome players, or anything like that. So these are the No Recoil ON and OFF bytes including the address.
Code:
Red Boxes: 0x14492C (On - 0x60, 0x00, 0x00, 0x00 | Off - 0x41, 0x82,0x00, 0x0c)
Double click the "No Recoil ON" button and put the following code:
Code:
byte[] norecoilon = new byte[] { 0x60, 0x00, 0x00, 0x00 };
PS3.SetMemory(0x14492C, norecoilon);
What you're doing here is declaring a byte named "norecoilon" remember that the name of the byte doesn't really matter, you can name it "34itji43tjj4" because it doesn't really matter. Then the ON bytes for No Recoil are 0x60, 0x00, 0x00, 0x00 so you're putting the bytes into hex format.
Then your setting the memory with the No Recoil address which is 0x14492C, and then beside it your putting the byte norecoilon. So lets conclude this: You've made a byte named norecoilon, that byte has the bytes in hex: 0x60, 0x00, 0x00, 0x00. Then your setting the memory to your PS3 by setting the bytes in "norecoilon" to the offset 0x14492C.

Now you do the same thing for No Recoil OFF but its different bytes. Your code for No Recoil OFF would look like:
Code:
byte[] norecoiloff = new byte[] { 0x41, 0x82,0x00, 0x0c };
PS3.SetMemory(0x14492C, norecoiloff);
Now you're finally finished, all you have to do now is run the .exe. You can debug it meaning if any random error occurs in the code the program will stop or run it without debugging meaning just running it straight from the .exe. To debug all you have to do is click "Start" at the top of Visual Studios or if you want to run it without debugging click the little arrow beside "Start" and it will drop down with another Start feature, click that start.
Spoiler:
fa32edd7a96eda8cb6fc38037c2c5994.png



Now you're finally done, to distribute your file click "Save All" (there was a pic earlier in the thread) and find the Visual Studios 2013 folder. Mine is located in my documents, once you have found it. Click on it, click "Projects" and find the folder with your tool that you've just created. You're tool will be in the debug folder. Remember if you're going to send people the tool remember to send them with the dll's. You can add a lot more non host mods or anything you would like from this offset thread:
Hi. My name is Phillip Morgan. I just made a Resident Evil 6 1.06 RTM Tool for PS3. Are there any ways to make a God Mode and Infinite Ammo and Infinite Stamina,etc for the Campaign Mode Characters?
 
General chit-chat
Help Users
  • No one is chatting at the moment.
  • @ God:
    It was good talking with you as well, you have a great night! We will talk later bro
    +1
  • Chat Bot:
    QM|T_JinX has joined the room.
  • @ QM|T_JinX:
    have a great weekend everybody ill be back after the weekend
  • Chat Bot:
    OkBrruh is our newest member. Welcome!
  • Chat Bot:
    uncrtin is our newest member. Welcome!
  • Chat Bot:
    BigTechModz is our newest member. Welcome!
  • @ BigTechModz:
    Hey this is RexMods I don’t remember the login to my old account so I made a new one I am now known as BigTechModz
  • Chat Bot:
    QM|T_JinX has joined the room.
  • Chat Bot:
    QM|T_JinX has joined the room.
  • Chat Bot:
    iDior2K is our newest member. Welcome!
  • Chat Bot:
    QM|T_JinX has joined the room.
  • Chat Bot:
    KillerDino49 is our newest member. Welcome!
  • Chat Bot:
    Xiomber is our newest member. Welcome!
  • Chat Bot:
    QM|T_JinX has joined the room.
  • Chat Bot:
    QM|T_JinX has joined the room.
  • Chat Bot:
    QM|T_JinX has joined the room.
  • Chat Bot:
    051magalhães is our newest member. Welcome!
  • Chat Bot:
    wheelcore is our newest member. Welcome!
  • Chat Bot:
    QM|T_JinX has joined the room.
  • Chat Bot:
    zeppiemods66 is our newest member. Welcome!
  • Chat Bot:
    Scrapper is our newest member. Welcome!
  • Chat Bot:
  • Chat Bot:
  • Chat Bot:
    Christo has joined the room.
  • Chat Bot:
    QM|T_JinX has joined the room.
      Chat Bot: QM|T_JinX has joined the room.
      Back
      Top