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

news/2024/11/16 19:25:41/

   经过一天的努力终于琢磨出怎么修改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修改。示例游戏是《牧场物语:矿石镇的伙伴》

   


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


   



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


   


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


   


   然后选择“添加代码”


   


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


   


   就能看到金手指了


   


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


   
   


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


   


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


   


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


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


   


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


   


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


   


   


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


   


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


   


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


   


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

   


   


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


   


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


   


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


   


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


   


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


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


   


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


   


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


   
   


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


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



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


http://www.ppmy.cn/news/590881.html

相关文章

教育部发布高考志愿填报十问十答

中国教育报讯(记者 欧媚)近期,各省(区、市)正陆续发布2023年高考成绩,并即将启动高考志愿填报工作。记者近日从教育部获悉,为更好地帮助广大考生和家长了解高考志愿填报相关事项,教育…

桥接模式(Bridge)

定义 桥接是一种结构型设计模式,可将一个大类或一系列紧密相关的类拆分为抽象和实现两个独立的层次结构,从而能在开发时分别使用。 前言 1. 问题 假如你有一个几何形状(Shape)类, 从它能扩展出两个子类&#xff1a…

支付中心“收银台“设计方案

01.收银台的产品架构 重点收银台架构的三个方面: 1.公司所支持的收银台种类以未来拓展倾向 2.支付方式的枚举及根据业务发展预判拓展倾向 3.收银台服务端的能力建设规划和选择 02.收银台的业务架构 收银台,是支付的起点,所以无论是何种…

错误:No module named ‘osgeo’

from osgeo import gdal 报错:No module named ‘osgeo’ pip install gdal 会出错,也不知道什么原因。 解决方案: 下载whl,然后pip install .whl即可。 详细步骤如下: whl下载地址:https://www.lfd.uci.edu/~go…

window office

两种情况:账号的密钥和本地office的密钥 微软官网:https://account.microsoft.com/services 微软服务支持:https://support.microsoft.com/zh-cn/home/contact?SourceAppsmc2&ContactUsExperienceEntryPointAssetIdaccount.microsoft.co…

keychron K3 键盘和 Windows11 操作系统的笔记本电脑通过蓝牙配对出现问题的解决方案

最近一直使用良好的 keychron k3 键盘,忽然出现了一些问题。 我用的是 Windows11 操作系统。keychron k3 采用蓝牙模式连接。能够成功配对,但 Connected 状态只能持续1秒钟,随即就变成了 Paired 状态。 下图是短暂的1秒钟能够成功连接的状态…

Backtrader官方中文文档:第十五章Live Trading 实盘交易

本章主要内容:https://backtrader.com/docu/live/live/ 下所有和实盘交易有关的文档内容。 由于交易环境不同,本章涉及的关键词可能翻译不准。 核心价值在于如何对接实盘的数据量冲击,由于译者的实盘操作不是这种方式。故对翻译理解可能存在一定偏差,还请理解。 Live Tr…

【edusrc案例-姿势总结(三)】幼儿园-漏洞挖掘链-寻找姿势

edusrc漏洞挖掘链-思路总结(三) 漏洞点 漏洞挖掘链 .net程序-未授权访问 收集*.xxx.edu.cn子域名 》 httpx观察子域名响应 》 403响应(一个子域名带admin) 》 .net的程序的403》尝试后台和越权路径 》 绕过存在admin/login.asp…