自己动手丰衣足食-自己动手修改GBA ROM游戏文件

   经过一天的努力终于琢磨出怎么修改GBA的游戏文件也就是俗称的ROM文件,起因是因为偶然看到二手GBM,顿时抑制不住买了一台,可惜买得晚了,完美运行游戏又带金手指功能的烧录卡买不到了。SUPERCARD烧录卡看评论说费电,玩游戏会拖慢什么的,最后权衡再三买了个EZ4烧录卡,缺点就是不能开金手指。但是我这种从小开惯金手指的人没有金手指怎么驰骋游戏?好了废话不多说开始进入正题,看本文最好有80x86汇编语言基础,理解什么是代码段,什么是数据段,用CE OD调试修改过PC游戏的最佳。


   当然没有的话我也试着尽量让没基础的人能看懂,之前搜了半天百度只找到一篇很晦涩的博文说了这个方法,本人弄出来了就打算写篇图文教程造福广大没有条件开金手指的玩家。



   首先是工具:


1.UltraEdit  


   大名鼎鼎的16进制文件阅读/修改工具,这个工具主要是修改GBA ROM文件,并保存。


2.NO$GBA1.4C  


   这个并不是那个著名的NDS模拟器,虽然名字一样,但却是个GBA ROM的DEBUG调试工具,用它能帮助定位需要修改的代码段。


3.VisualBoyAdvance1.6


   一定得是这个低版本的GBA模拟器,我被卡了大概一早上就是因为我本来用的是1.72版本的,1.72和NO$GBA1.4C载入后的地址不一样,有偏移。


4.arm汇编手册(中文版)


   GBA的CPU用的是ARM汇编语言,有80x86汇编语言基础的朋友可以自己查手册,实现更自由的修改。


   http://download.csdn.net/detail/l198738655/9903635     本文提到的工具



   好了,我们开始,首先我们来学习怎么找或者说制造VisualBoyAdvance模拟器用的金手指,因为只有会找金手指代码了才能进行下一步的ROM修改。示例游戏是《牧场物语:矿石镇的伙伴》

   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第1张图片


   现在的钱是500,选择菜单栏中的 修改→搜索修改 


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第2张图片



   按照图片上的设置来,然后点 开始→搜索


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第3张图片


   出来一个结果,有时候会出现多个结果,这时候只能去买点东西让数值变动重新搜索,好在GBA游戏比较简单数据比较少,不会出现PC游戏一个数值几百上千个结果的事情,可能也是我这个存档是游戏刚开始,所以干扰数据比较少。


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第4张图片


   然后选择“添加代码”


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第5张图片


   然后选择 修改→修改代码列表 


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第6张图片


   就能看到金手指了


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第7张图片


   金手指已经生效,钱被修改成了800。此时要记下“修改代码列表”里的地址“020068b4”这就是存储金钱的地址,这个地址下存储着金钱数“320”这是个16进制数,换算成10进制正好是800,不清楚的人可以自己用WINDOWS的计算器点“查看”切换成程序员来换算。做到这一步就可以关闭VBA模拟器了,现在打开NO$GBA1.4C。


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第8张图片
   


   首先选择 设置→模拟器设置 然后按照下图设置按键


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第9张图片


   用鼠标点一下游戏画面才能开始操作游戏


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第10张图片


   在红框框内 右键→GO to...


   
   
   然后再对话框内输入刚才找到的地址,输入完后点OK


   


   点击OK后跳转到了光标所在的地址,我此时游戏内的金钱是1600,换算成16进制数是“640”,但这里显示的是4006是怎么回事呢?这涉及到一个大端小端问题,弄过80x86汇编的人会知道,这里就不展开来说,这里用的是小端模式,计算机的数据都是以字节为单位显示的,一个字节简单来说就是两个数字“00”,所以1600的16进制也可以写成“0640”,小端模式就是要把数据按字节为单位前后颠倒,本来从左往右读的改成从右往左,两位两位的读,故改成“4006”。然后我们用快捷键Ctrl+B,然后在弹出的对话框中输入 [020068b4]!


   


   来设置条件断点,让游戏访问这个地址里的金钱数据时断下来,我们就能知道是那一段代码在访问这个内存地址,然后我们买个东西,花点钱让代码段访问以下这个地址


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第11张图片


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第12张图片


   买一袋种子后断在了红框框处,现在按一下键盘上的"Delete"键删除[020068b4]!这个断点。这一句我们不用理他,看这一句的上面一句


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第13张图片


   sub是减法 这一句的意思是,r0寄存器里的值- r1寄存器里的值结果放回r0寄存器。r0=r0-r1


   


   我们在这一句上下一个断点,就是点一下这行末尾出现“BRK”就说明断点已经设立,然后买个120G的东西,又断下来了,我们看r0和r1寄存器此时的值


   


   r0为640就是10进制的1600;r1是78就是10进制的120。所以我们只要编辑这行代码让它由减变加,就能实现买东西反而倒找钱的功能了。在下了断点那行再点一下,"BRK"消失,取消断点,然后在此行上右键选择“Change Instruction”来修改代码

   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第14张图片


   


   修改成add r0,r0,r1,然后确定


   


   然后我们用鼠标点击一下游戏画面,让游戏跑起来


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第15张图片


   因为我们在买的时候断下,修改代码后重新运行,此时游戏逻辑已经改变,现在钱变成了1720正好是1600+120,但是此时我们要把代码改回去,为何呢?因为这个调试器是无法保存我们的修改的,我们得改回去然后用之前提到的16进制文件编辑器来查找到这段代码,再修改后才能保存。改回去后记住红框框内的4个字节。


   


   我们要记下图片中的这4个字节:1C211A40,然后转换成小端形式:211c401a,然后我们用UltraEdit打开 牧场物语.gba 文件


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第16张图片


   然后在这里按Ctrl+F搜索字符串:211c401a 
     
   


   看我们找到了,如果怕不是这个我们可以再搜索一次就会出现


   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第17张图片


   说明这4个字节的组合是唯一的


   


   我们要把sub修改成add,也就是要把 211c401a 改为 211c4018,选中a,用键盘改它为8,然后保存退出就修改成功了。此时把这个ROM文件拖入任何一个烧录卡,任何设备的GBA模拟器,修改都会生效,没有金手指也能纵横GBA世界。修改GBA ROM主要就是找SUB或ADD语句,下面再以机战OG2为例子,说一个用加法实现减钱效果的代码的修改。有时候代码实现减法不一定会用SUB而是用ADD,用一个正数加上一个负数也能实现减法。


   
   自己动手丰衣足食-自己动手修改GBA ROM游戏文件_第18张图片


   这一句的意思是r1=r1+r2,经过测试,去地图里杀敌后增加资金也是这段代码,把ADD改为SUB的话减钱就是加钱,加钱就减钱,问题在于资金数肯定有个上限,超出后恐怕会溢出导致存档损坏什么的,单纯的把加改成减并不安全,我的办法是把add r1,r1,r2改为add r1,r1,1,也就是不管买什么都只加1块钱。但问题来了,杀敌一台本来该加2000也变成了只加1。不过这也不是什么大问题,想加钱的时候换成正常ROM不想花钱了换成改过的ROM,存档是不受影响的。


   我已经把修改后的ROM文件一起打包到工具压缩包里了,有兴趣的同学可以自己拿模拟器或者GBA试试。



转载请注明出处尊重一下鄙人的劳动成果多谢多谢

你可能感兴趣的:(汇编,游戏,rom,GBA修改,游戏修改,GBA金手指)