Skip to content

Open Source Rise of Kingdoms Stats Management Tool. Track TOP X Players of kingdom / alliance / honor leaderboard.

License

Notifications You must be signed in to change notification settings

Cyrexxis/RokTracker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Rok Tracker

Important Notes

  • Version 5 config is not compatible with Version 4 config, so you need to adjust the config accordingly.
  • It is important to use \\ in the config json bluestacks path (not \), otherwise you will get a JSONDecodeError. Please open no issues for that.

Latest Changes

  • Experimental support for LD Player
  • Wiki tab where more stuff gets explained
  • Seed Scanner that works like alliance scanner only for kingdom (fast way to get only kp or power)
  • Now possible to choose the output format (xlsx, jsonl or csv)
  • Default adb port can be changed
  • Option to check for plausible governor power during kingdom scan on the power ranking page

Summary

Open Source Rise of Kingdoms Stats Management Tool. Track TOP X Players in kingdom / alliance / honor leaderboard. Depending on what you scan the resulting .xlsx will look different:

For kingdom rankings Governor Id, Governor Name, Power, Kill Points, Ranged Points, T1/T2/T3/T4/T5 Kills, Total kills, T4+T5 kills, Dead troops, RSS Gathered, RSS Assistance, Helps and Alliance name will get saved.

For the honor and alliance rankings only the governor name and the score will be saved. Because there is no guarantee that the name is correct a picture of the name will be saved in addition.

This is a heavily modified version of the original tool from nikolakis1919 in the repository https://github.com/nikolakis1919/RokTracker

There are two ways of installing and using the scanner. The first is an exe file with no need for other software to be installed. This approach is described under simple installation. The second way of using the scanner is by using the python files directly. However, for that approach you need to have a running python installation and have to install the dependencies manually. This is explained under advanced installation.

Simple installation

Required

  1. Bluestacks 5 Installation https://www.bluestacks.com/de/bluestacks-5.html
  2. To use tesserocr you also need to download the trained tesseract models https://github.com/tesseract-ocr/tessdata
  3. Adb Platform Tools Download and Extract(See Important Notes) https://dl.google.com/android/repository/platform-tools_r31.0.3-windows.zip
  4. Tested on Windows 10 and 11, could work on Windows 7

Setup

  1. Download the latest release for your system here: Latest Release (choose RoK Tracker.zip)
  2. Extract the zip in the folder where you want the scanner to be installed in
  3. Download the requirements 2 (tessdata) and 3 (platform-tools) and extract them in the deps folder
    • tesseract needs to go into deps/tessdata/
    • platform-tools need to go into deps/platform-tools
    • complete tree how the folder should look like are here
  4. Configure your Bluestacks instance according to the instructions

Usage

  1. Adjust the default options in the config.json file to your liking
  2. Double-click the exe like any normal program and enjoy the scanner
  3. The results of the scans can be found in the scans-* folder, where * is the type of scan you are doing

Simple File/Folder Structure

./
├─ _internal/
│ ├─ ...
├─ deps/
│ ├─ inputs/
│ ├─ tessdata/
│ │ ├─ *.traineddata
│ │ ├─ ...
│ ├─ platform-tools/
│ │ ├─ adb.exe
│ │ ├─ ...
├─ config.json
├─ *.exe

Advanced installation

Required

  1. Bluestacks 5 Installation https://www.bluestacks.com/de/bluestacks-5.html
  2. Python 3.11 Installation https://www.python.org/downloads/release/python-3110/
  3. To use tesserocr you also need to download the trained tesseract models https://github.com/tesseract-ocr/tessdata
  4. Adb Platform Tools Download and Extract(See Important Notes) https://dl.google.com/android/repository/platform-tools_r31.0.3-windows.zip
  5. On Windows "Microsoft Build Tools für C++" might be required for some python packages https://visualstudio.microsoft.com/de/visual-cpp-build-tools/
  6. Tested on Windows 10 and 11, could work on Windows 7. Tested with Python 3.11.0 and 3.11.7.

Setup

  1. Download the latest release for your system here: Latest Release (choose the source code option)
  2. Download and install Python and Build Tools for C++
  3. Download the requirements 3 (tessdata) and 4 (platform-tools) and extract them in the deps folder
    • tesseract needs to go into deps/tessdata/
    • platform-tools need to go into deps/platform-tools
    • complete tree how the folder should look like are here
  4. Open your terminal in this folder and create a venv via python -m venv venv
  5. Activate that venv via ./venv/Scripts/activate
  6. Install the python requirements via pip install -r requirements_win64.txt
  7. Configure your Bluestacks instance according to the instructions

Usage

  1. Open a terminal in your rok tracker folder
  2. Activate the venv via ./venv/Scripts/activate
  3. Start the scanner:
    • python kingdom_scanner_console.py for the CLI version of the kingdom scanner
    • python kingdom_scanner_ui.py for the GUI version of the kingdom scanner
    • python alliance_scanner_console.py for the CLI version of the alliance scanner
    • python alliance_scanner_ui.py for the GUI version of the alliance scanner
    • python honor_scanner_console.py for the CLI version of the honor scanner
    • python honor_scanner_ui.py for the GUI version of the honor scanner
  4. The results of the scans can be found in the scans-* folder, where * is the type of scan you are doing

Folder/File Structure

./
├─ deps/
│ ├─ inputs/
│ ├─ tessdata/
│ │ ├─ *.traineddata
│ │ ├─ ...
│ ├─ platform-tools/
│ │ ├─ adb.exe
│ │ ├─ ...
├─ config.json
├─ *_scanner_console.py
├─ *_scanner_ui.py
├─ ...

Features

Kingdom Scanner

  • Complete kingdom ranking scan
  • Detection for wrong kills based on if kills to kill points are correct
    • In case something doesn't check out the corresponding images are saved in the manual_review-folder (prefix F) and a warning is logged in the log file.
  • Option to try to recover kills if wrong kills are detected
    • Nevertheless the same images as for a fail get copied to the manual_review-folder (prefix R) and an info is logged in the log file.
  • Detection of inactive accounts
    • an inactive account is an account that cannot be clicked in the kingdom rankings
    • those are skipped automatically, and it is optionally possible to save a screenshot of the name in the inactives-folder.

Alliance and Honor Scanner

  • complete alliance ranking scan
  • complete personal honor ranking scan
  • due to how the game works the names are very inaccurate, and it is not possible to track the governor ID

Bluestacks 5 Settings

Main configuration

  • Display Tab (Screenshot)
    • Resolution: 1600x900
    • DPI: Custom (450)
  • Advanced Tab (Screenshot)
    • Android Debug Bride: Turned on

Configuration for automatic port detection

  • Change the entry bluestacks_config in the config.json file of the scanner to match the location of your conf file
    • This file is located in your Bluestacks installation folder. If you don't know where you installed it, chances are good that it is located at C:\ProgramData\Bluestacks_nxt\bluestacks.conf
  • Make sure to use the correct instance name. The scanner asks for a Bluestacks name and looks for that name in the config file
  • If you don't find a bluestacks.conf file chances are high that your installation always uses the same port. The default should be 5555, that's also what the scanner assumes. If you change the port you have to manually change it in the scanner.

Important Notes

General

  1. It is recommended to use a venv to keep your global python installation clean of the dependencies. After setting up the venv and activating it, you can install the requirements with the requirements.txt file (more about that in the "Usage" section)
  2. The scanner does not need admin privilege to run
  3. Make sure your folder structure matches the expected structure
  4. Bluestacks settings must be the same as in pictures above. THIS IS VERY IMPORTANT!
  5. BE CAREFUL to always copy the .xlsx file from the scans folder when it is finished, because in the next capture, there is a chance for it to get overwritten (very low chance).
  6. Chinese letters might not be shown properly in CMD, but they are visible in the final .xlsx file.
  7. You can do whatever you want in your computer when tool is scanning. Only be warned that copying can result in wrong governor names if it coincides with the name copy of the script.
  8. Game Language has to be English. Anything else will cause trouble in detecting inactive governors. Change it only for scan, if yours is different and then switch back.

Scan

  1. In order to get only your kingdoms ranks, the character that is currently logged in game must be in HOME KINGDOM, else you will get all the players in your KvK including players from different kingdoms.
  2. The view before running the program should be at the top of power rankings or at the top of kill points rankings for the rok-scanner.py or at the top of an alliance leader board of your choice or at top of the personal honor rank for the alliance-scanner.py. No move should be made in this window until scanning is done.
  3. [Only for kingdom scan] Account must be lower in ranks than the amount of players you want to scan. e.g. Cannot scan top 100 when character's rank is 85. Use a farm account instead.
  4. [Only for kingdom scan] Resume Scan option starts scanning the middle governor that is displayed in screen. The 4th in order. So before starting the tool make sure that you are in the correct view in bluestacks.

Error reporting / help

Recently people started to random guess my discord name. So I'll just make it public here, it's simply cyrexxis same as my Github username.

I try my best to help those people, but I will set up some rules for help requests:

  • Send me a message request (I am on the official RoK Server and the Chisgule server)
  • In this message request explain your problem and post your log file.
    • Simply saying it doesn't work is not enough, and you will get ignored
  • If you respect that you should get an answer from me. But there is no guarantee, because I am doing this project fully in my free time.

A second way I will set up is Github discussions. The advantage with that is that other people see the mistakes and errors, maybe it helps them to fix them by their own.

About

Open Source Rise of Kingdoms Stats Management Tool. Track TOP X Players of kingdom / alliance / honor leaderboard.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages