EMU618社区

 找回密码
 立即注册
搜索
查看: 2227|回复: 4

[转载HACK教程] 游戏修改基础知识(游戏特攻队GameSF:Thor撰写)

 关闭 [复制链接]

签到天数: 2153 天

[LV.Master]伴坛终老

发表于 2009-3-9 23:14:36 | 显示全部楼层 |阅读模式
游戏修改基础知识
9 ~: z8 i/ y* C) Y2 O0 K
& K/ I7 @4 S% Z5 R0 d5 \
9 W. e0 q) @0 }  s2 {游戏天使语:本来不推荐这篇东西的,但太多网友需要了,本着为大众服务的思想,贴出来了,希望大家在修改的同时节制一下。! w7 J# s/ {& Z
' v0 D3 i5 x, U2 K5 T
# M- W8 Q" @9 M! }
第一节 理论分析2 [1 X  o: l# @* p

, Z: y3 S7 D! D+ M0 }, Q游戏修改并不是什么难事,首先要认清游戏本质,在修改之前,要清楚“自己所面对的只是一串数字”,修改精华和难点也都在于这里,阁下能不能成功的把这串数字和游戏中的HP、MP、物品、魔法等一一对位将成为整个修改全局的中心点。
8 c7 B) z3 z8 i+ {0 v; f3 {, j
# f' F3 {: Z' u7 ^) ?因为PC不同于街机和次世代游戏机,PC的硬件和软件都是开放式的,才给我们以修改的可能。
7 Q4 u$ s2 m) _2 U+ }- t' o
" w3 ^3 ?& S2 n. `- c/ D. l& o3 K要使电脑执行一程序(这里就是阁下所谓的“游戏”),它首先把重要的数据读入内存。当阁下发出存盘命令时,程序自动将有关数据存入硬盘。游戏修改就抓住这两个环节,或改写内存中的数据(称为动态修改),或改写硬盘上的存盘文件(称为静态修改)。
/ d( [) P0 q$ h! t! W9 m
# H! u8 Y! e" h" L4 f7 G  h% [2 T7 R9 O: T7 F. N$ C* D
动态修改,常规步骤如下:6 F) a% u5 z7 O: h9 g8 e
1:确定欲改数据,记下它的值。
. b( s5 ~7 S/ Z4 `' P9 r2:呼叫修改器,在数据栏里输入欲改数据。
. i* ^+ N. k& f+ m$ R3:回到游戏中,想办法改变欲改数据(比如,花掉一些钱或吃药加点血等)。
0 s- r" O: q  Y$ ]' Q; \2 n' x* H4:再次呼叫修改器,在数据栏里输入改动后的数据。
" t  L( C. W) u( f: m9 \! \$ u
' @5 V. Q; B) B如此基本上就可以找到数据了,但有时找到的数据地址有多个,那么还要再进行一次或几次原有数据地址基础上查找。这样做实际就可概括为“筛选”。找到了数据就能改了,但有时无论怎么找都有两个以上地址,那么就把内存数据列表打开看看,一般来说,会有其中一个地址的内存数据非常简洁,那就是这个了。如果每个地址的数据列表都是差不多的,那干脆都改了。7 E& x) [: X, J

1 u* Y$ M/ ?2 q# u改数据的基本方式有三种:
4 j2 S% M, v) _3 i4 k1.普通修改,是简单地把数据改过来,一旦修改数值应该发生变化,则修改数据会在修改基础上进行应当的加减变化。+ N) o% F( f; ^  C
2.锁定修改,修改器自动把数据锁定,如果修改数值应该发生变化,修改器也会强制此数值不变,或在极短时间内修改器会强制此数值变回玩家所规定的数值。+ m8 Q. L3 Y1 ~4 C. \- H1 t
3.热键修改,可以理解为“手动锁定”,即数据改变后按一下设定好的热键,数据马上就又回到了设定值。% h9 _3 V  u6 B# {  ~$ |- u
8 b; j) `: C, ^, k* S# M6 Y) Z
静态修改,一般是利用存盘纪录的数值差找出地址,进行修改,一般为普通修改,多用于不支持切换的游戏,或防动态修改的游戏,需修改量大等情况下。
% ^8 Q0 r9 T, j9 g+ S* y4 u: U, q7 u( A! Q% X9 [3 F
多数游戏中都有各种可用数值来标定的属性或特性,譬如RPG中的经验值、生命值,动作游戏中的弹药数和金钱数等等,这些都可作为修改对象。更高级的还可以通过修改程序中的代码对一些道具进行修改,其实质都是因为游戏是用数值编写的。但数据的存放和大家的平时习惯不同,一般存为16进制、10进制、8进制、2进制,而且会出现数值“倒装”譬如对一个数——9999,转为16进制为27 0F,但在电脑里的存放则为0F 27,正好两位想倒,所以一定要注意。
% T5 V" v' l. \. i$ z$ r! @, X
& n& l2 H7 d: G0 r) z  e对于初学者来说,一般还是选一些明显的具有数值属性的目标修改,待积累了一定经验后再深入。) z( _& J  d$ L, Q' j5 S. Y

# F5 q) N$ b0 f& u1 \' c+ \另外,游戏修改一般要有游戏修改工具,在学习下面的课程时请拿好阁下的家伙,动态修改如:金山游侠、东方不败、Game Master、FPE等都很适合初学者,静态修改如JediEdit、UltraEdit、HEX Workshop等,另外静态修改有时也可以利用动态游戏修改工具完成。
- ~! n8 z( l+ z1 C+ Q8 G总之,修改游戏比起编程、解密一类的要简单得多。记得有人说过:“游戏是通向电脑世界的捷径,那么修改游戏则是捷径中的捷径。”' t6 M' g( t& m! i, ]

' Z( z5 o/ Y2 Q& [$ X/ h( y第二节 进制换算- j6 M5 l1 K2 o5 _& \

5 d' H' A; M- A! e; u" s  d! p大家在生活中一般接触较多十进制,即1+9=10,有时也接触到了60进制,比如60分=1时。以上是逢十进一或逢六十进一的。其它进制还有二进制,三进制,四进制...n进制,只要数得出来都可以。电脑(特别是对于游戏来说)一般采用二,十,十六进制。, f9 M: k1 i& C7 g- c
2 b+ i' Q6 _2 y
现在的Windows都自带计算器,进制的转换可以不用手算,但是实践中进制转化会对修改者意想不到的方便,所以劝告大家不要松懈,把它当作基础的基础来学习。* ~  v0 [& Z% h& O6 k' ^- `) h
9 J1 v0 P8 [' R# }* k
首先学习几个概念:基数,权值。
+ ^4 q+ O# P: ^5 x5 P
9 C  G3 j, i, v逢n进一的n就是基数,基数为几就有几个数字,如二进制基数为二,则有0,1两个;八进制基数为八有0,1,2,3,4,5,6,7八个。总之从0开始,最后一位位n-1。而如十六进制等基数超过十的,从十开始为A(相当于10进制的10),B,C,D,E,F(相当于10进制的15)。
3 e2 M4 n  b7 }0 q  r. x3 l8 C6 ^* m" r2 Y
权可以这样理解,一种进制的某一个数的每位都有一个权值m,并且权值为位数减一,如个位上的数的权值为0(位数1-1=0),十位为1(位数2-1=1)。& A  p& R2 t5 G% u  N; z3 h
5 ?2 R  `+ r" `6 o2 {& Z
各个进制之间的转化一般分为两类。
6 v6 h# o1 V- [+ p# _  a( S  z4 @5 }0 G
十进制转换为其他进制:可以概括为“除基取余”。如十进制的12化为16进制,12/16=0余12,但十六进制是用C来表示的,所以十进制的10就是12进制的C;又如十进制30化为十六进制,30/16=1余14,第二次用商14/16=0余14,则十进制30转化为十六进制为1E(由后往前取),其他类推。十进制转化为二进制也是如此,如9/2=4余1,4/2=2余0,2/2=1余0,1/2=0余1,也就是1001了。10进制转化为其它进制,也是一样,但不常用,所以就不说了。
" N3 }: B8 }8 t7 D
; P: y: S! ~( L( B) m其它进制转化为十进制:可以概括为“按权展开”。知道了权值m,就可以转化了。 首先,每一位的位数乘以基数n的m次方,如八进制个位4,4x8^0=4(8^0等于8的0次方),百位4,4x8^2=256.最后加总。' g  u9 h- H  c' h$ k

2 B; J$ y8 K/ B- }另外一般默认十进制以d结尾,八进制为o,二进制为b,十六进制为h。+ z$ H# z% D* F  s
  N5 E  m% W% ~: S& s5 \
================================================
9 n( Z; D& z" q+ [; u6 Q下面来练习一下:$ P/ H) v1 L0 P5 N/ c0 N- x
1.420d=( )h
5 ^4 H3 b) q+ N2.420h=( )d
$ _5 d( [5 J# o. b- l5 E6 ]. u6 B3.110100100b=( )d
, v" ?3 {  j0 [, G) \& j4.420d=( )b
7 A) _$ v- C/ T: D' k/ H2 l5 f================================================1 h2 z$ h9 a6 r, ^9 @
答案:1、1A4;2、1056;3、420;4、110100100. d2 |3 W# Q1 S
================================================
  I" _- k/ J2 r$ ~
7 Q' O* V$ p7 R) f2进制和16进制的转化:有些情况中,常会遇到2进制和16进制转化如果通过二进制转换为十进制,再转换为十六进制完成,有很大麻烦,下面有一种方法,提高效率。$ s7 \' [( e% {( n8 C1 W& c

/ ~0 T- ]+ q/ v二进制到十六进制的转换。我们可以将二进制数由右至左分为几部分,每一部分有四位(因为2的4次方为16),不足四位的补0,如10111b,可分为0001(补了3个0)和0111两部分。然后将两部分分别化为十六进制,第一个是1,第二个是7。最后合起来,为17h。+ C. N- o9 R8 H% a
( Q' ^. m/ W% r8 k6 b- ?
十六进制到二进制的转换。同理,我们可将十六进制的每一位,一分为四,再合并即可。如13h,分为1和3两部分,在一分为四,0001和0011,合并去0,就是10011。, g3 u9 \' {! C4 K$ L( D* e- o

. v0 C: m  k/ Q/ C7 e" |进制的转化,就讲到这里,修改的一个要点,相信阁下已经掌握了。
- d+ h  O* O  i# i+ F4 S
& f1 U' w0 O$ p9 D第三节 数据存储
- D- \- G9 A- }! C% s/ s# d: k& S9 ~
$ S* t' h; E* }. {$ u2 S% K0 F位、字节:
8 Y) n& a; ?" ?+ S! W
$ i3 y7 T8 D3 F3 A1 c8 U在前面,大家知道了二进制的权为2,即它只有0和1两个数字组成,表示及运算都十分简单。因此在计算机中就把它作为数据的基本单位‘位’(bit),然后再把八个这样的位组成一个字节(byte),如 1001,0011。
/ ]* |" _& t/ _# h% r* j* C; U4 S1 w
好了,运用前面的进制转换知识将二进制1111,1111转换为十进制,为255,于是可知1字节的表示范围是0(0000,0000)--255(1111,1111)。在计算机中常用来表示数据的有二字节,四字节,八字节,十字节等,他们都可依照上法求的范围。(在FPE2000中的8,16,32就是指一,二,四字节)。3 x: t: ~: {# N: H& X- _
  r7 W  w0 @8 I8 o
另外,浮点数(即带小数点的小数)一般用四字节以上表示,视精度而定,对于初学者,也就不多说了。$ y3 A7 _5 a7 }/ j2 g: f

& K, {% D+ v# H  n& {* S5 ]0 |; ~原码、反码、补码: 3 b( k/ x3 [; d( `  c

( E  z/ Y7 Y) S% V4 c原码:一字节数据可表示的范围是0--255,那么负数又怎么表示呢?计算机中是这样规定的,用一个数的最高一位表示正负,0为正,1为负。例如0111,1111转换为十进制为127,1111,1111转换为十进制为-127,由此我们知一字节的范围为-127--127,其他字节的范围类推。7 v5 N; z0 P& a0 i$ z. D
7 C4 i# T. \+ P9 U
反码:上面讲的都是原码表示法,可在计算机中的数据都是以补码存放的,只有这样才能减轻cpu的负担。提到补码,就不得不提反码了。计算机中是这样规定反码的,如果是正数,则按原码形式不变,如127仍为0111,1111;而如果为负数则,第一位为1,其他各位取反(即0变为1,1变为0),如原码-127(1111,1111),表示为1000,0000。
  H6 C6 y# ^: B/ r1 i4 ^$ E7 }# w! E, j: c
补码:补码同上,如果是正数,则按原码形式不变,如127仍为0111,1111;如果为负数则除第一位为1外,其他各位取反加1,如-127,先取反为1000,0000,然后加1,为1000,0001。但1000,0000比较特殊,用它来表示-128,由此我们知补码可表示的范围是-128--127(因为-64d为1000,000b反码为1111,1111b补码+1不能用2byte表示)。
2 I7 b! _  f6 r
  o! @4 e. K3 ]0 {. ^' y' E4 B0 C数据存储:
" ]5 `2 a: J/ P! N: \& _# b; c# f  C
# r5 X( c* o) {3 W现在把所有的有用的数据集中起来放在一起,并取一个名字来代表这些数据的集合,这就是一个文件了。如存盘文件就是将游戏中某一场景的关键数据集中记录到一个文件中,那么下次读取这些数据也就可以接着玩了。
9 c% a: N$ k$ V. `6 ~$ W, [! a- h8 I* a0 x5 F
而且我们知道文件中数据的存放是有序的,以字节为单位,分别给他们编号,第一个字节为0,第二个为1……一定要注意的是第一个字节是0而不是1,这在后面会多次碰到。在许多地方所指的地址就是这些编号了。如一个二字节的数据,其第一个字节的地址为3,则整个数据的地址就为3。
; V, O$ d7 |' t另外注意的一点是,在内存(即文件)中二,四等多字节的数据,其存放的顺序是颠倒的;十六进制AA BB,你在编辑工具中将看到BB AA。 , y/ ^# M' Q8 _4 B3 u: _

: F) G! l6 A: {& [9 M* n# y游戏特攻队GameSF
! M: Z' ]3 K" [4 MThor撰写
4 j/ e/ V4 w+ }8 ]' V
* g% t  g! e( ^2 K! t' f[ 本帖最后由 疾风之狼 于 2009-4-10 19:36 编辑 ]

该用户从未签到

发表于 2009-3-10 00:19:30 | 显示全部楼层
沙发啊!
1 W' |: d% W. ^0 L3 k# o0 S说真的,这些东西我还不懂呢

签到天数: 41 天

[LV.5]常住居民I

发表于 2009-3-10 14:24:18 | 显示全部楼层
这个对新人很有帮助滴说···:good:

该用户从未签到

发表于 2009-3-15 17:08:16 | 显示全部楼层
可惜, b. S5 P$ Z5 d% u" {
我的数学不太好

签到天数: 6 天

[LV.2]偶尔看看I

发表于 2009-3-15 17:13:52 | 显示全部楼层
这个其实含义不大
! e0 _  \1 {% Z( z8 r
2 e/ S: |4 D% B) Y9 ~0 a6 ^2进制教学对新人反而是个障碍
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|国治模拟精品屋 ( 沪ICP备15012945号-1 )

GMT+8, 2025-12-8 00:08 , Processed in 1.104492 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表