测试合并
Go to file
Akash Mozumdar c6b7c6ba22
Merge pull request #115 from TokcDK/master
Russian localization for GUI and Readme
2019-03-26 15:30:16 -04:00
cmake build system improvements 2018-10-19 15:55:48 -04:00
extensions fix race condition 2019-02-28 01:40:40 -05:00
GUI rename 2019-03-13 11:54:19 -04:00
include update version 2019-03-24 23:01:09 -04:00
texthook more accurate h code 2019-03-20 18:55:55 -04:00
x64libs static link lua 2019-02-16 22:53:19 -05:00
x86libs static link lua 2019-02-16 22:53:19 -05:00
.gitattributes Line ending attributes for window LF 2016-12-12 00:50:06 +09:00
.gitignore ignore resource editor files 2019-01-15 04:29:17 -05:00
CMakeLists.txt rename 2019-03-13 11:54:19 -04:00
CMakeSettings.json fix file ends 2018-12-18 16:55:07 -05:00
deploy.ps1 Compress-Archive uses wrong directory separator 2019-03-20 18:56:37 -04:00
LICENSE add license and update readme 2018-05-20 21:21:37 -04:00
README_ES.md improve screenshot 2019-02-18 01:16:53 -05:00
README_JP.md improve screenshot 2019-02-18 01:16:53 -05:00
README_RU.md . 2019-03-25 16:27:45 +05:00
README_SC.md rename 2019-03-13 11:54:19 -04:00
README.md . 2019-03-25 16:27:45 +05:00
screenshot.png resize 2019-02-18 01:27:41 -05:00
text.cpp Russian localization for Textractor (readme + GUI) 2019-03-25 16:18:24 +05:00

Textractor

How it looks

Español简体中文日本語Русский

Textractor (a.k.a. NextHooker) is an open-source x86/x64 video game text hooker for Windows/Wine based off of ITHVNR.
Watch the tutorial video for a quick rundown on using it.

Donate

Download

Releases of Textractor can be found here.
The last release of ITHVNR can be found here.
Try running vc_redist.x86.exe if you get an error when starting Textractor.

Features

  • Highly extensible
  • Auto hook many game engines (including some not supported by VNR!)
  • Hook text using /H "hook" codes (most AGTH codes supported)
  • Directly extract text using /R "read" codes

Support

Please let me know of any bugs, games that Textractor has trouble hooking, feature requests, or other suggestions.
If you have trouble hooking a game please email me a place where I can freely download it, or gift it to me on Steam.

Extensions

See my Example Extension project to see how to build an extension.
See the extensions folder for examples of what extensions can do.

Contributing

All contributions are appreciated! Please email (no, I'm not busy!) me at akashmozumdar@gmail.com if you have any questions about the codebase.
You should use the standard process of making a pull request (fork, branch, commit changes, make PR from your branch to my master).
Contributing a translation is easy: just translate the strings in text.cpp as well as this README.

Compiling

Before compiling Textractor, you should get Visual Studio with CMake support, as well as Qt version 5.11
You should then be able to simply open the folder in Visual Studio, and build. Run Textractor.exe.

Project Architecture

The host (see GUI/host folder) injects texthook.dll (created from the texthook folder) into the target process and connects to it via 2 pipe files.
Host writes to hostPipe, texthook writes to hookPipe.
texthook waits for the pipe to be connected, then injects a few instructions into any text outputting functions (e.g. TextOut, GetGlyphOutline) that cause their input to be sent through the pipe.
Additional information about hooks is shared through a file view (a.k.a. section object) that is mapped to a reference to the TextHook class.
The text that the host receives through the pipe is then processed a little before being dispatched back to the GUI.
Finally, the GUI dispatches the text to extensions before displaying it.

Developers

If you're on this list and want your link changed let me know.

Special Thanks

  • Everybody adding issues!