Hi everyone, i am currently writing a Windows app in my spare time to display the trains travelling on the underground… this app will be free.
I initially had a picture in my head of just flashing dots for each train as it moves up and down the line… but it will be more than that, for example, users will be able to switch on/off each line and do various other customizations.
Its in its early stages at the moment but the footings are in place… i will upload a couple of screen shots that show each line and with trains just on the Bakerloo line for now…
What i am after to help me with development is a list of the location strings that are visited for each direction on a line… for example with the Bakerloo line we have this string “North of Piccadilly Circus”, however, is that for a train travelling North or South?
Surely someone must have all the correct locations for each direction?
For example trains going one stop from Kings Cross to Euston are southbound and the Victoria Line and Northern bound and the Northern Line (City) branch
The currently conventions are listed in the working timetables…
There are plenty of times where the direction from “here” to the Line end is because the lines have switched oved convention might just be “zone 1 to the end of the line”
Firstly, I would like to ask why you want to have a list of locations? What would you do with such a list? What problem are you trying to solve?
The Location attribute is only there to provide a piece of text about the current location of a train, but it’s not intended to be parsed or used in any way other than simply displaying that snippet of text.
I’m unable to provide a list of locations, and even if I could, I’m not sure it would be useful to you. But there may be a different way to solve the same problem, so if you can let us know more about the problem, we could try to provide suggestions.
For example, if you want data about the position of each train so that you can plot them on your diagrams, there are better ways to do that than using the Location field.
Unfortunately only using the location string is unlikely to yield any accurate results, even if you do get your hands on the full list of possible strings, because as you have identified, some strings can be used for track sections in either direction.
Another example of strings you’ll see often is something like “Approaching Oxford Circus” or “Departing Oxford Circus”, without any platform or direction information. Because of this, you can’t really judge the direction of a train based off of a single observation of a track section description.
Your options here are:
Use the Unified API (api.tfl.gov.uk/Line/bakerloo/Arrivals) instead of the TrackerNet APIs, as this will provide you with a direction value along with the currentLocation string for every predicted train.
When using the TrackerNet API, consider which platform the train is being returned under to figure out the current direction. Note that this may cause some weird behaviour at terminal/common turnaround stations or where the signalling system doesn’t know which platform a train will go into yet, so will duplicate it across multiple platforms.
Track the same train across multiple track sections, until you see it go into a track section that does disclose the direction (e.g. “Between Oxford Circus and Green Park” vs “Between Green Park and Oxford Circus” reveals that a train is going southbound vs northbound respectively). You can then presume that the direction remains the same until you see it in a track section going the opposite direction. Unfortunately there doesn’t seem to be a full list in the public domain anywhere, so you’ll need to poll the API every so often to get a wider sample of all the possible locations you may encounter.
The most accurate but most time-consuming method would be to rely on the much more specific track section codes (e.g. TV6523 is one of the codes for the southbound Victoria line platform at Oxford Circus). Note that you’ll need to use the PredictionDetailed feed of TrackerNet, not the PredictionSummary, as the codes aren’t included in the summary. For more detail on how to work with these you can watch a talk from EMF2022 about this at https://www.youtube.com/watch?v=osAfQLD59Kc
I dont want to use the Unified API if i can help it because it does not (i believe?) include all underground stations etc. Although i did try it and found it easier to use than the Trackernet data.
However i have now gone down the route of parsing the XML file myself rather than using any extra packages, i am not even using JSON yet although that may change later on.
And yes, i did discover that the strings ‘approaching station’ and ‘left station’ kind of left me in no mans land as far as knowing which side of the actual station they were referring to!
And i did notice the codes (such as TV6523) in the PredictionDetailed output, however i have not got a clue as to what the actual location for each code number is? Is there any info out there?
Quite the opposite - it is TrackerNet which currently does not have a detailed prediction for all stations (Battersea Power Station and Nine Elms, specifically) - the Unified API covers all TfL stations and more, as the name suggests.
The limitation of the Unified API comes in the detail of the data, rather than the coverage or scope - for example it does not provide you with track section codes.
There is no comprehensive list or graph of all the track sections in the public domain, and the diagrams that show an overview of them are internal only. TfL has previously rejected FOI requests for the TrackerNet diagrams, so the only way to build out a list/graph of your own is to do what eta did in her talk, as linked above.
I have now added Line Status boxes on the left of the screen, these will automatically update and move into the correct order depending on their status, i.e. Severe at the top etc… You can then move the mouse cursor over the box to get more details…
The buttons on the right will not be in the final program and are just used for testing.
Most of the functionality will be on the mouse right click menu.
Anyway, the main reason for the upload is to ask if i could put a London Underground roundel graphic in my program… their is a perfect space for this in the bottom right once them buttons have been removed.
Thanks for your reply, with link and your kind comment regarding my windows app.
It still has a long way to go and i realise that once i have added all the other lines with their stations etc then its going to look very busy on there… but then that was the original idea… i wanted it to look alive!
As for the TFL roundel, it would definitely be nice to have the underground logo on there but i will see what happens… if i think it means others taking control of my app then i will probably not let that happen and i would then just design a completely different logo to match the apps name.
I will give updates on the apps progress as and when i can.