MuniLines Bag
A hand-sewn tote bag with a textile based on SFMTA public transit routes.
Inspired by the patterns of transit routes, the MuniLines bag transforms SFMTA route data into a beautiful multi-colored textile. Printed on fabric, I hand-sewed this textile into multiple tote bags. The complex shapes and random patterns in transit routes make them the perfect lines to transform into a fabric pattern.
Limited edition: only 4 have been created to this date, in the hands of SFMTA Director of Transformation Jeffery Tumlin, transit advocate Hayden Miller, and a family member.
data:image/s3,"s3://crabby-images/5c6c2/5c6c2fd87526175c246426215b0f82ed9f319035" alt="The MuniLines bag being helf"
The Data
Transit route data was imported from SFMTA's transit data API. SFMTA contracts Umo IQ, a Cubic service, for their arrival predictions and general realtime technology.
SFMTA rolled out more accurate predictions in early 2023 under a new contract with Cubic. Unfortunately, this contract didn't include a public API, discontinuing the API route I used :(
Today, route shape data might exist on 511.org's GTFS API, but it'll be a bit more complex.
A sandbox route with the same data structure still exists: https://retro.umoiq.com/service/publicJSONFeed?command=routeConfig&a=sfmuni-sandbox
data:image/s3,"s3://crabby-images/a155a/a155a93ae889741502942c1bc9166e83fd0ee439" alt="Screenshot of the code generating the pattern"
Transformation
The MuniLines pattern transforms a distinct map and into an art piece that appears more like a line-based drawing than data. With a closer look, though, the lines vividly represent transit routes, both in shape and color.
At first, I transformed the latitude and longitude positions of routes into pixel coordinates, recreating the San Francisco shape. I experimented with different colors, shapes and sizes.
data:image/s3,"s3://crabby-images/110a0/110a0a84e8f4f5572d546f6a7c06c26163e712da" alt="Generated muni bus lines pattern"
data:image/s3,"s3://crabby-images/6b2eb/6b2ebaa12263ce885a5c22d8b9ec3902c93f9d81" alt="Generated pattern with bus stop dots"
data:image/s3,"s3://crabby-images/80292/80292f57416464bb8aab2aa41026b10a2ca7d053" alt="Generated pattern with messy lines"
data:image/s3,"s3://crabby-images/93a33/93a33948b1a1e662faaed559c91963d871c14699" alt="Generated thicker muni bus lines pattern"
To create more of a random and expandable pattern, I settled on randomizing the positions and colors of routes. Each route is duplicated 10 times, randomly translated, and set to a random transit-map-like color.
data:image/s3,"s3://crabby-images/c7b8b/c7b8b64f6212e1cf983b530c645f9c1148939850" alt="Few, randomly positioned bus lines"
data:image/s3,"s3://crabby-images/e95d6/e95d63569f248a57c54c9181a98592c52f6f6a70" alt="More randomly positioned bus lines"
data:image/s3,"s3://crabby-images/5a0c7/5a0c7587fd895620bca35a4e182bf04b94537095" alt="Dark theme, zoomed in pattern"
data:image/s3,"s3://crabby-images/3f900/3f900a11c7dd97adae231d822f70d6adec03d4eb" alt="Light theme, zoomed in pattern"
Final Textile
I created a larger, zoomed-out version to be uploaded and printed on fabric. I really like how the diagonal Market Street line is visible throughout.
data:image/s3,"s3://crabby-images/906fb/906fb5dd17829b085d0b6faf4184fe829fc1ed46" alt="The full final textile pattern"
The final pattern was printed on Cypress Cotton Canvas by Spoonflower.
The Bag
I cut rectangles out of the two-yard piece of canvas, and sewed them into a tote bag. It was challenging to prevent the fabric from fraying, lots of little strands are present in the final designs!
But at least I have a transit map with me at all times. If I can figure out what each line is.
data:image/s3,"s3://crabby-images/b3783/b3783f400c751e0ee290e9470df3eac297fed494" alt="Sewing hems on the bag"
data:image/s3,"s3://crabby-images/03e4b/03e4bc4f7119e9e7da3d76024831703f5eb29a1c" alt="Sewing the handles onto the bag"
data:image/s3,"s3://crabby-images/70d7a/70d7a0d33ebf5042eb62a10a7b69c38da9734533" alt="The bag laid out on a table"
data:image/s3,"s3://crabby-images/57929/5792955558252ab6dc20ddcd9d5b44e88c3593b5" alt="A corner of the bag"
data:image/s3,"s3://crabby-images/c0772/c07722db710f5f8a81450ce1be5b2513917a6284" alt="The bag in use on a rainy day"