冒险解谜游戏中文网 ChinaAVG

标题: 【汉化资料】【原创】基于图像比对和代理DLL的汉化新方法 [打印本页]

作者: shane007    时间: 2009-5-24 21:08
标题: 【汉化资料】【原创】基于图像比对和代理DLL的汉化新方法
对图片字库的汉化进行了一个阶段的研究,现在我提出一种基于图像比对和代理DLL的汉化新方法。5 R# K  S6 H4 q4 Y5 f- z- [
是否能最终实现心里还没有底,不过先写个初稿放在这里,希望各路高手指正。
( V6 r" v; p0 d! e  S
- I% R3 [3 }6 D8 \9 r. p2 E! x4 _运用代理DLL技术,我们可以重写DirectX内部的所有成员函数。(对代理DLL技术不清楚的朋友可以参考我发的相关帖子): N$ j  n0 \* W! B* y( P  o

( f% m: `5 @8 _* z1 T5 ^# U4 J$ s; j在DirectX调用Present函数时,我们应该有办法取到前台表面和后台表面的内容。其中必有准备向屏幕显示的内容。我们可以实现修改字幕的内容,一般一个游戏的内容有几千句,我们可以用3-4位2进制数来表示。就是说,我们把字幕的内容修改为0000-FFFF。对话字幕一般在屏幕上的显示位置是固定的,都是在某个矩形区域内部。所以我们可以事先截取字幕显示后的样子的小型图片,也就是0000-FFFF用游戏字体所显示的样子。然后在Present函数中,对前台表面和后台表面的相应区域进行对比,可以进行异或操作,如果得到一个全0的字节数组应该就能说明这2块区域完全相同。同时就说明游戏要显示某句字幕,由于这3-4个字母的区域很小,所以比对应该会很快。然后我们可以把这句字幕相应的中文字幕显示到前台表面或后台表面。这样基本就完成了汉化的过程。
5 F! w: d, Z! H
( }8 Q$ F& Z$ K6 H当然,这样的汉化方法有一定的局限性,比如,字幕显示的区域要相对固定。, b8 k' g2 b# {- [! V+ _) j
如果字幕的显示位置是随机的,那这种方法就不太适用了。
作者: 妖妖梦    时间: 2009-8-25 05:37
你说的办法跟游侠汉化植物大战僵尸一样啊?
8 }3 Y; T3 F% f2 A5 R! ^! \  G4 l% t
用内挂DLL显示中文
作者: shane007    时间: 2009-8-25 06:10
你研究过植物大战僵尸?
4 |% P/ R( e5 s: ?- n0 [/ Y" }不妨仔细说说?
作者: 妖妖梦    时间: 2009-8-25 06:46
下载游侠发布植物大战僵尸汉化版分析一下就知道1 E  u. l$ d) q% ^  ^4 k. ^! C+ q$ q
http://game.ali213.net/thread-2789340-1-2.htmlu: h3 i: X9 l! ~; a: d; f- ~" @6 m
7 \' Q  r; L6 N# `6 ^3 a( q
很明显,采用了DLL内挂显示中文和 系统自带中文字体 关于细节游侠没有透露 不管怎么说,已经证明你的是对的,同时看到了小游戏的汉化希望
作者: 颂妖精    时间: 2009-8-29 14:39
楼上网址最末处多了个U
( d* f) V/ ]4 ~, Y, Y4 j" y; ~' D* l$ K! a2 T2 m
偶下到的直接打到一起了的版本2 f# L/ D6 v1 o) F0 b
所以不知道E文版啥样子的……
% _1 h! A2 @) F8 D7 {& C
* N  _) g- S$ m( E/ ]在游戏目录下找到了GIF的字符库
$ Q& S1 G& Q  L0 r6 \7 q+ n同时还有各种字符的定义及宽度设定文件
7 A  [8 c, ]+ s3 _$ u# v  [! {如果从这里着手4 O3 E  v2 `7 d5 k2 p9 X7 l/ T
用UinCode来对应汉字表% h0 l! O- H- j5 z% \
应该也很容易做的/ B' B9 G/ v! V9 m! C

9 C2 `1 f& e+ x5 N, e汉化主要工作
  M' a6 L$ q! R9 i0 C应该是制作图形界面
& A' U, D. _/ F; s( {: k难点则在说明文字部分的显示
4 q1 w, |2 X  L( V在主目录下可以看到GDI42.DLL% Z( ?& V; A8 ^" A8 |( X! p1 v
估计是用来加载中文显示的( p9 }- @& D6 I6 x. i2 P$ g9 _! M
自带了一个方正少儿体
  n, E" W3 O3 b' P, \& L不过在偶这儿却没能正常加载
作者: solidji    时间: 2010-4-1 18:16
如果是2D游戏,对白输出都是通过固定API函数,很容易做. 看这个textout hook 项目
$ h4 j5 I# v4 Jhttp://blgames.proboards.com/ind ... =250&page=1
7 j- ?, |2 s) g4 r5 Q  H
1 O; S% V$ z' `8 A. Q2 t D3D游戏的话,基于速度的考虑,一般是采用纹理方式输出,纹理又分动态静态,
9 u$ b" I  y" z* l, n+ @游戏初始化时一次性创建,显示的时候填充
$ t0 A5 b! N- o& ~$ y用到哪里创建哪,每句话根据码表单独创建一个纹理
8 R4 o! |: W/ g效率最低的方法是用GDI建立纹理数据,然后填充纹理,最后绘制' _  _7 _' ]# u: \5 u; l! l3 n
效率最高的方法是直接存储每个字母的对应纹理坐标,使用固定纹理
/ b/ n3 U6 D) d  j折中的方法是建立每个字母的图像数据,使用哪个字母就建立对应的纹理) o$ K* y) z8 P9 x- r( h+ e+ w
总之很多方法,首先要兼容这些不同的输出方式) J: L2 d# y4 C& u( n$ z
, W) V& ^5 u  f# B% s6 R$ T. z& r
另外一点主要是如何区分一般游戏纹理,与文字纹理,还有带文字的图片纹理,
9 q; [0 E) f' e, d- ^4 `然后找到一个不影响效率的时机用自己的汉化后纹理来替换  n* H$ u# U: U# R) I

& y/ H$ k6 q, r! X* j, c+ [. x/ ]LZ 比对图片二进制数据的方式不知能否区分出各类纹理
作者: shane007    时间: 2010-4-1 19:22
感谢楼上的发言,我提出的只是一个思路。; Y) ^8 k( E4 o1 N0 n. a, D
要实现的话真的是难度很大,我对directx的理解游戏。! z. E5 W7 R% m; @6 O0 B# f5 G/ n% E
直白地说,我提出的思路目前并无具体方法来实现它。




欢迎光临 冒险解谜游戏中文网 ChinaAVG (https://chinaavg.com/) Powered by Discuz! X3.2