Easily export light cones, relics, and character data from Honkai: Star Rail to JSON format using OCR.
The resulting output can be used in various community-made optimization tools including:
Download latest HSR Scanner and then run as administrator (required to simulate keyboard and mouse presses).
- Set text language to English.
- Set in-game resolution to one that has an aspect ratio of 16:9 (e.g. 1920x1080, 1280x720).
- In Star Rail, look away from any bright colours. Yes, really. The inventory screen is translucent and bright colours can bleed through to make the text harder to accurately detect and recognize. Looking towards the ground usually works in most cases, as long as the right side of the screen is relatively dark. (Double-check by opening the inventory page and see if the item info on the right contrasts well with the background.) You can skip this step if you're only scanning characters.
- Open the cellphone menu (ESC menu).
- Configure the necessary scanner settings in HSR Scanner.
- Start the scan.
- Do not move your mouse during the scan process.
- Once the scan is complete, some additional time may be required to process the data before generating the final JSON file output.
As of v0.3.0
, the app's database is updated separately from this repo. If the database version doesn't match the latest game version, then the database hasn't been updated yet.
HSR Scanner has the following scan options:
- Select whether to scan light cones, relics, and/or characters.
- Include UID in the JSON file (disabled by default).
- Set output location for the JSON file.
- Filter light cones, relics, and characters based on a minimum rarity or level threshhold.
If Star Rail lags on your system, the scanner might perform its inputs too fast for the game to respond or re-render in time. To work around this, there are two types of delays that can be increased in the configure tab:
- Navigation delay for navigating between different pages (inventory, character details, etc.)
- Scan delay for clicking between individual items (relics, light cones, and characters).
The scanner uses b
and c
by default to navigate to the inventory and character screen, respectively. If you changed these hotkeys, you will need to update the corresponding key in the configure tab.
If debug mode is enabled, the scanner will save ALL the screenshots taken during a scan to a debug folder in the specified output directory.
The output is loosely based off of Genshin's .GOOD
export format. I don't expect this output to change anytime soon. If a breaking change has to made to the output, the version will be incremented by one to differentiate the change from previous versions.
- SPD substats have a hidden decimal place that the scanner cannot directly parse. As a result, reproducing your character's stats (such as on optimizer websites) will most likely have a lower SPD stat than what it displays in-game. This is not an issue with the scanner, but rather a limitation when obtaining substats through OCR.
- If the Trailblazer variant was not determinable during the scan or previous scans, it will default to
Stelle
. - Flat substats and percentage substats are differentiated by an underscore suffix in the key.
- Main stats will never have an underscore suffix.
- Substats are sorted in the order of:
HP, ATK, DEF, HP%, ATK%, DEF%, SPD, CRIT Rate, CRIT DMG, Effect Hit Rate, Effect RES, Break Effect
. This ordering applies for every relic with the exception of newly upgraded relics, which gets fixed when the user logs out and logs back in. As a result, the scanner will automatically sort the substats before generating the output. - The
_id
value for light cones and relics is arbitrarily assigned during the scanning process. It is intended for easy lookup in case of any errors logged during the scan, for double-checking or manual correction purposes. - For
Dan Heng • Imbibitor Lunae
, the character•
will appear as\u2022
in the JSON output. This is the Unicode representation of the character and is a normal behaviour when special characters are included in JSON. Most modern environments will automatically render\u2022
as•
when displaying or processing the JSON. - For character traces,
ability_#
andstat_#
are ordered by earliest availability (i.e.stat_1
can be unlocked at Ascension 0, butstat_2
requires Ascension 2).- In the case of ties, namely two stat bonuses X and Y that both unlock at the same Ascension level, the one that visually connects to the highest
stat_#
on the in-game character traces page comes first. For example, if a stat bonus X connects tostat_2
and stat bonus Y connects tostat_1
, then X would bestat_3
and Y would bestat_4
.- If X and Y both connect to the same
stat_#
(only found in Erudition), then visually assign from bottom to top.
- If X and Y both connect to the same
- In the case of ties, namely two stat bonuses X and Y that both unlock at the same Ascension level, the one that visually connects to the highest
- The exact string values used can be found here.
Current output sample:
{
"source": "HSR-Scanner",
"build": "v1.1.0",
"version": 3,
"metadata": {
"uid": 601869216,
"trailblazer": "Stelle"
},
"light_cones": [
{
"key": "Cruising in the Stellar Sea",
"level": 60,
"ascension": 4,
"superimposition": 2,
"location": "Seele",
"lock": true,
"_id": "light_cone_1"
},
{
"key": "Meshing Cogs",
"level": 1,
"ascension": 0,
"superimposition": 5,
"location": "",
"lock": true,
"_id": "light_cone_2"
}
],
"relics": [
{
"set": "Celestial Differentiator",
"slot": "Planar Sphere",
"rarity": 5,
"level": 15,
"mainstat": "Wind DMG Boost",
"substats": [
{
"key": "HP",
"value": 105
},
{
"key": "CRIT Rate_",
"value": 3.2
},
{
"key": "CRIT DMG_",
"value": 17.4
},
{
"key": "Effect Hit Rate_",
"value": 8.2
}
],
"location": "Bronya",
"lock": true,
"discard": false,
"_id": "relic_1"
},
{
"set": "Thief of Shooting Meteor",
"slot": "Body",
"rarity": 4,
"level": 0,
"mainstat": "Outgoing Healing Boost",
"substats": [
{
"key": "HP",
"value": 30
},
{
"key": "HP_",
"value": 3.4
}
],
"location": "",
"lock": false,
"discard": true,
"_id": "relic_2"
}
],
"characters": [
{
"key": "Seele",
"level": 59,
"ascension": 4,
"eidolon": 0,
"skills": {
"basic": 4,
"skill": 6,
"ult": 6,
"talent": 6
},
"traces": {
"ability_1": true,
"ability_2": true,
"ability_3": false,
"stat_1": true,
"stat_2": true,
"stat_3": true,
"stat_4": true,
"stat_5": true,
"stat_6": false,
"stat_7": false,
"stat_8": false,
"stat_9": false,
"stat_10": false
}
},
{
"key": "Bronya",
"level": 20,
"ascension": 1,
"eidolon": 0,
"skills": {
"basic": 1,
"skill": 1,
"ult": 1,
"talent": 1
},
"traces": {
"ability_1": true,
"ability_2": false,
"ability_3": false,
"stat_1": true,
"stat_2": false,
"stat_3": false,
"stat_4": false,
"stat_5": false,
"stat_6": false,
"stat_7": false,
"stat_8": false,
"stat_9": false,
"stat_10": false
}
}
]
}
Check sample_output.json for a full-sized, unfiltered example.
HSR-Scanner is not affiliated with, endorsed, sponsored, or approved by HoYoverse.