Players Customization
If you haven't already, first read the customization overview.
This is the simplest format to define players in a League File:
{ "version": 43, "startingSeason": 2019, "players": [ { "firstName": "Andrew", "lastName": "Phillips", "tid": 0, "ratings": [ { "diq": 50, "dnk": 50, "drb": 50, "endu": 50, "fg": 50, "ft": 50, "hgt": 50, "ins": 50, "jmp": 50, "oiq": 50, "pss": 50, "reb": 50, "spd": 50, "stre": 50, "tp": 50 } ] }, { "firstName": "Heriberto", "lastName": "Braman", "tid": 0, "ratings": [ { "diq": 50, "dnk": 50, "drb": 50, "endu": 50, "fg": 50, "ft": 50, "hgt": 50, "ins": 50, "jmp": 50, "oiq": 50, "pss": 50, "reb": 50, "spd": 50, "stre": 50, "tp": 50 } ] }, { "firstName": "Draft", "lastName": "Prospect", "tid": -2, "ratings": [ { "diq": 50, "dnk": 50, "drb": 50, "endu": 50, "fg": 50, "ft": 50, "hgt": 50, "ins": 50, "jmp": 50, "oiq": 50, "pss": 50, "reb": 50, "spd": 50, "stre": 50, "tp": 50 } ], "draft": {"year": 2020} } ] }
Some things you might want to know:
tid is the team ID number, ranging from 0 to N (usually 30) for the teams in your league. Additionally,
- -1 is for free agents
- -2 is for undrafted players
- -3 is for retired players
If don't include a draft year, draft prospects will appear in the upcoming draft. If you want to specify multiple upcoming drafts, you need to use the draft.year
property, like is done for Draft Prospect above. If you do this, make sure to also set startingSeason
, otherwise your draft classes will shift when the default starting season changes each year.
If you specify less than 70 prospects in a draft class, random prospects will be created to reach that limit.
In the example above, there are only two players defined. If your file doesn't include at least 10 players on each team, then bad things will happen when you try to use it. You should also include a good amount of bad/mediocre young players beyond the 10 man limit or as free agents (maybe 30-60 in total). Otherwise, you might end up running out of free agents before the free agent pool naturally fills up with undrafted prospects and unsigned players, and then bad things will happen.
Jersey numbers can be defined at the root of the player object like "jerseyNumber": "25",
. For players with stats included, use the same property inside a stats object to override the jersey number for a specific season.
Ratings should be on a scale from 0 to 100 with a mean of about 50 and about half of the players between 35 and 65. Descriptions of rating categories:
hgt
: height, which factors into pretty much everything - this is meant to also reflect things like standing reach and wingspan, and it is used in game simulations rather than the player's "true" height in feet/inches. For a realistic professional basketball league, take the player's height in inches, subtract 66, and multiply by 3.70. Then maybe add or subtract a little based on wingspan. This means 0 is 5'6" and 100 is 7'9" (with a little wiggle room for wingspan).stre
: strength, which influences defense, rebounding, and low post scoringspd
: speed, which influences ball handling, fast breaking, and defensejmp
: jumping, which influences finishing at the rim, rebounding, blocking shots, and defenseendu
: endurance, which governs how fast a player's skills degrade as he gets tiredins
: low post scoringdnk
: dunking/layupsft
: free throw shootingfg
: 2 point jump shot abilitytp
: 3 point shootingoiq
: offensive IQ (affects many aspects of offense)diq
: defensive IQ (affects many aspects of defense)drb
: dribbling (also influences passing, since you can pass easier if you're not worried about losing the ball)pss
: passingreb
: rebounding
It's best not to specify additional properties in the ratings object, like ovr
, pot
, pos
, and skills
. If you simply leave them out, then they will be auto-generated on import.
You can optionally include a URL for an image to be used instead of a randomly-generated face by putting "imgURL": "http://www.example.com/img.jpg" in the root of a player object.
There are several other pieces of information you can include, such as stats from previous seasons. Look in an exported League File from one of your leagues to see what else can be added.