All the credit goes to JoshCheek - https://github.com/JoshCheek/bitmoji.
This repo is just to try this all out.
Examples:
I've discovered that there are additional comics, which aren't listed in the API output, eg: 10211795
- Me:
134229688_7-s4
You can find other users with the find-users.html
page.
The number between the underscore seems to be about which version of that person being rendered into that pose,
eg if they change their bitmoji, then the suffix will increment. I'm not sure what the s1
or the v1
are about,
I've seen as high as v3
, but it doesn't seem to change anything when I edit that piece.
- Individual comics are in .imoji (1117 of them) replace the
%s
with an avatar id - Multi-avatar comics are in .friends (296 of them) replace both
%s
with an avatar id (eg from .imoji or .friends) https://render.bitstrips.com/v2/cpanel/:comic_id-%s-v1.png?option1&option2&...
transparent=1
to set the bg to truepalette=1
no ideawidth=200
scale image width to 200 pixels
https://render.bitstrips.com/render/:comic_id/%s-v1.png?option1&option2&...
cropped=%22body%22
you can also set cropped to"head"
outfit=971786
put the user inhead_rotation=1
rotate the head to position 1body_rotation=1
rotate the body to position 1pd2={"mouth":"_blank"}
insidepd2
, you can put any of these keys:[ "beard", "brow_L", "brow_R", "cranium", "detail_E_L", "detail_E_R", "detail_L", "detail_R", "detail_T", "ear_L", "ear_R", "eye_L", "eye_R", "eyelash_L", "eyelash_R", "eyelid_L", "eyelid_R", "eyelines_L", "eyelines_R", "forehead", "glasses", "hair_back", "hair_front", "hairbottom", "hat", "jaw", "mouth", "nose", "pupil_L", "pupil_R", "stachin", "stachout", "tongue"]
Friends, generated with:
cat bitmoji.json | jq '.friends|map([.src]+.tags)[]' -c | ruby -ne 'puts $_ % [%w[134229688_7-s4 270452369_2-s1 134229688_7-s4]].*(2).map(&:sample)' | ruby -rjson -ne 'url, *tags = JSON.parse($_); puts "<div class=\"friends\"><img src=\"#{url}&width=300\" /><ul>#{tags.map {|t| "<li>#{t}</li>"}.join}</ul></div>"; BEGIN { puts "<style> body * { margin: 0; padding: 0; display: inline-block; } li { display: block; } .friends { width: 300px; } </style>" }' > friends.html
Individual, generated with:
cat bitmoji.json | jq '.imoji|map([.src]+.tags)[]' -c | ruby -ne 'puts $_.sub "%s", %w[134229688_7-s4 270452369_2-s1 134229688_7-s4].sample' | ruby -rjson -ne 'url, *tags = JSON.parse($_); puts "<div class=\"friends\"><img src=\"#{url}&width=300\" /><ul>#{tags.map {|t| "<li>#{t}</li>"}.join}</ul></div>"; BEGIN { puts "<style> body * { margin: 0; padding: 0; display: inline-block; } li { display: block; } .friends { width: 300px; } </style>" }' > imoji.html
Packs (also individual), generated with:
cat bitmoji.json | jq '.packs[]|.templates[]|[.src]+.tags' -c | ruby -ne 'puts $_.sub "%s", %w[134229688_7-s4 270452369_2-s1 134229688_7-s4].sample' | ruby -rjson -ne 'url, *tags = JSON.parse($_); puts "<div class=\"friends\"><img src=\"#{url}&width=300\" /><ul>#{tags.map {|t| "<li>#{t}</li>"}.join}</ul></div>"; BEGIN { puts "<style> body * { margin: 0; padding: 0; display: inline-block; } li { display: block; } .friends { width: 300px; } </style>" }' > packs.html
Male outfits:
cat bitmoji.json | jq '.outfits|[.male][]|.brands[]|.outfits[]|[.image, .description]' -c | ruby -ne 'puts $_.sub /(?<=\/)\d+_\d+-s\d(?=-v)/, %w[134229688_7-s4 270452369_2-s1 128256895_1-s1].sample' |ruby -rjson -ne 'url, *tags = JSON.parse($_); puts "<div class=\"friends\"><img src=\"#{url}&width=300\" /><ul>#{tags.map {|t| "<li>#{t}</li>"}.join}</ul></div>"; BEGIN { puts "<style> body * { margin: 0; padding: 0; display: inline-block; } li { display: block; } .friends { width: 300px; } </style>" }' > male_outfits.html
Female outfits:
cat bitmoji.json | jq '.outfits|[.female][]|.brands[]|.outfits[]|[.image, .description]' -c | ruby -ne 'puts $_.sub /(?<=\/)\d+_\d+-s\d(?=-v)/, %w[134229688_7-s4].sample' |ruby -rjson -ne 'url, *tags = JSON.parse($_); puts "<div class=\"friends\"><img src=\"#{url}&width=300\" /><ul>#{tags.map {|t| "<li>#{t}</li>"}.join}</ul></div>"; BEGIN { puts "<style> body * { margin: 0; padding: 0; display: inline-block; } li { display: block; } .friends { width: 300px; } </style>" }' > female_outfits.html