最近我又想出来一种新的汉化方法,按照惯例,在动手实现之前,先把思路写出来。然后再逐步实现。
; Z5 O" ?8 c$ L' u* y T4 {& u! W1 |
- i( G1 S7 U0 S( O8 m) z基本思路 3 m+ [" v* ~. A; Q/ l
! V: w* b( R( x n' c4 T
我们知道,现在大多数AVG都是全程语音的,也就是说,有一部分字幕每个都各自对应了一个语音文件。 , J+ y0 G9 L9 \ K, i
这个语音文件可以是一个单独的文件,也可以是一个包含在包文件里面的子文件。语音文件和字幕文件不同,一般不是在游戏的一开始载入内存,而是在游戏播放语音文件文件时才打开这个文件。 % X: c6 j/ Y r4 T: M
/ G% ~ H. e- w* L. o- S e
所以,如果我们可以监视到游戏打开一个语音文件或者是打开一个含有语音文件的包文件并且在语音文件所在的偏移处进行读取操作的话,就说明游戏马上就要播放这个语音文件。同时也就是说明游戏马上就要显示和这个语音文件相对应的字幕了。这就是一个切入口。 6 }- m0 ^7 W C9 _3 K
: U: x1 K3 i0 a! n2 L1.监视文件操作
% N, @, E9 Y/ t( w0 p( V6 i+ I下面来说说如何监视文件操作,其实还是用老方法,那就是HOOK。具体怎么个HOOK法呢?我最近找到了一份著名文件监视工具Filemon的源代码,只要我们把这份源代码研究清楚了,可以说,Filemon能监视到的文件操作我们也能监视到。
+ v+ J2 F) _4 o9 o8 N$ {1 t* J( I7 o1 c4 I
2.利用共享内存文件实现进程间通讯
x$ g$ u T5 j: T% j在监视到文件操作以后再怎么办呢?自然是要报告给我们的一个程序,然后让这个程序在屏幕上输出 ' h% r' x# [! n; o7 p9 M
我们翻译以后的中文字幕。那么通过什么机制向我们的程序报告呢?我想,利用共享内存文件是一个
* f# j7 u2 H3 Y) Q+ ~3 u8 ?好方法。HOOK工具监视到语音文件的操作以后,就向共享内存文件里写入一些标志和有关的信息。共享内存文件主要的功能就是用来实现进程间通讯的嘛。
# L/ R" f7 p3 c6 A' r1 K9 g J: [4 V, W3 [# c" u
3.利用代理DLL或是OverLay技术实现输出中文字幕 & ]# Y& i3 A$ s& K& l/ F
上面说的HOOK工具是信息的发送方,那么信息的接受方是说谁呢?接受方应该是向屏幕输出中文字幕的程序。我考虑可以用代理DLL或是OverLay技术来实现。 / H* i) |8 A2 \
对于DirectX8,9的游戏,我们可以用代理DLL,由于游戏在不断地刷新游戏画面的时候都会调用present函数, 在present中我们可以插入一段代码来监视共享内存文件,如果发现共享内存文件存在有关语音文件的信息的时候,就向屏幕输出相应的中文字幕。注意在输出中文字幕以后要把共享内存文件里面的有关语音文件信息删除掉。中文字幕输出的时间长度可以实现设定好或者是根据字幕的长度计算后得出。
" y3 }; W9 ]+ o1 O0 J7 q6 @8 B/ j: K: [4 c* s/ r/ l
未完待续。。。 |