Textractor/README.md

75 lines
4.1 KiB
Markdown
Raw Permalink Normal View History

2018-09-29 16:05:08 -04:00
# Textractor
2015-04-02 22:48:34 +09:00
2019-02-26 04:04:40 -05:00
![How it looks](screenshot.png)
2019-05-31 19:29:17 -04:00
[Español](README_ES.md) ● [简体中文](README_SC.md) ● [日本語](README_JP.md) ● [Русский](README_RU.md) ● [Bahasa](README_ID.md)
2019-02-26 04:04:40 -05:00
**Textractor** (a.k.a. NextHooker) is an open-source x86/x64 video game text hooker for Windows/Wine based off of [ITHVNR](http://www.hongfire.com/forum/showthread.php/438331-ITHVNR-ITH-with-the-VNR-engine).<br>
2019-06-05 16:58:45 -04:00
Watch the [tutorial video](https://tinyurl.com/textractor-tutorial) for a quick rundown on using it.
2019-01-15 04:43:26 -05:00
2019-02-15 13:08:22 -05:00
[![Donate](https://www.paypalobjects.com/en_US/i/btn/btn_donate_SM.gif)](https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=akashmozumdar%40gmail.com&item_name=Textractor%20development&currency_code=USD)
2019-02-26 04:04:40 -05:00
## Download
2018-10-21 16:31:19 -04:00
2019-02-13 21:33:57 -05:00
Releases of Textractor can be found [here](https://github.com/Artikash/Textractor/releases).<br>
2019-02-26 04:04:40 -05:00
The last release of ITHVNR can be found [here](https://drive.google.com/open?id=13aHF4uIXWn-3YML_k2YCDWhtGgn5-tnO).<br>
2019-05-31 19:29:17 -04:00
Try running vc_redist if you get an error when starting Textractor.
2016-12-15 22:30:45 +09:00
## Features
2019-05-31 19:29:17 -04:00
- Highly extensible and customizable
2018-09-29 17:42:44 -04:00
- 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
2016-12-15 22:30:45 +09:00
2019-02-13 21:33:57 -05:00
## Support
Please let me know of any bugs, games that Textractor has trouble hooking, feature requests, or other suggestions.<br>
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](https://steamcommunity.com/profiles/76561198097566313/).
2018-08-05 19:10:55 -04:00
## Extensions
2018-09-23 18:34:53 -04:00
See my [Example Extension project](https://github.com/Artikash/ExampleExtension) to see how to build an extension.<br>
See the extensions folder for examples of what extensions can do.
2018-08-05 19:10:55 -04:00
## 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.<br>
2018-12-19 16:07:46 -05:00
You should use the standard process of making a pull request (fork, branch, commit changes, make PR from your branch to my master).<br>
2019-02-01 16:56:10 -05:00
Contributing a translation is easy: just translate the strings in text.cpp as well as this README.
2018-08-05 19:10:55 -04:00
## Compiling
2018-10-21 16:31:19 -04:00
Before compiling *Textractor*, you should get Visual Studio with CMake support, as well as Qt version 5.11<br>
You should then be able to simply open the folder in Visual Studio, and build. Run Textractor.exe.
2018-08-05 19:10:55 -04:00
## Project Architecture
2019-03-13 11:54:19 -04:00
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.<br>
Host writes to hostPipe, texthook writes to hookPipe.<br>
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.<br>
2019-05-27 14:16:29 -04:00
Additional information about hooks is exchanged via shared memory.<br>
The text that the host receives through the pipe is then processed a little before being dispatched back to the GUI.<br>
Finally, the GUI dispatches the text to extensions before displaying it.
2018-08-05 19:10:55 -04:00
2016-12-15 22:30:45 +09:00
## Developers
2018-12-18 00:13:40 -05:00
If you're on this list and want your link changed let me know.
2019-01-11 17:15:10 -05:00
- Textractor made by [Me](https://github.com/Artikash) and [DoumanAsh](https://github.com/DoumanAsh)
- Spanish translation by [scese250](https://github.com/scese250)
2018-12-18 00:13:40 -05:00
- Turkish translation by niisokusu
- Simplified Chinese translation by [tinyAdapter](https://github.com/tinyAdapter)
- Russian translation by [TokcDK](https://github.com/TokcDK)
2019-05-31 19:29:17 -04:00
- Indonesian translation by [Hawxone](https://github.com/Hawxone)
2019-01-11 17:15:10 -05:00
- ITHVNR updated by [mireado](https://github.com/mireado) and [Eguni](https://github.com/Eguni)
- ITHVNR originally made by [Stomp](http://www.hongfire.com/forum/member/325894-stomp)
- VNR engine made by [jichi](https://archive.is/prJwr)
- ITH updated by [Andys](https://github.com/AndyScull)
2018-09-02 19:45:18 -04:00
- ITH originally made by [kaosu](http://www.hongfire.com/forum/member/562651-kaosu)
2019-01-11 17:15:10 -05:00
- Locale Emulator library made by [xupefei](https://github.com/xupefei)
2018-08-25 15:45:35 -04:00
- MinHook library made by [TsudaKageyu](https://github.com/TsudaKageyu)
2016-12-15 22:30:45 +09:00
## Special Thanks
- Everybody adding issues!