Make your own custom snapcode
- Query the Snapchat API to get snapcode
- Send snapcode to PHP script to add necessary tags
- Select the colors using jscolor picker
- Render the SVG as a canvas
- Convert the canvas to PNG
- Download the PNG
- showcase your cool snapcode 😄
I made a simple php script that inserts id tag in the svg to be able to modify it via css or using javascript.
<?php
header('Access-Control-Allow-Origin: *');
$username = $_GET["username"];
$size = $_GET["size"];
if(strlen($username)>0){
//snapchat api call
$url = "https://feelinsonice-hrd.appspot.com/web/deeplink/snapcode?username=".$username."&type=SVG&size=".$size;
$file = file_get_contents($url, false, $context);
$pos =strpos($file,"svg");
$file = substr($file, 0, $pos+3)." id=\"tag\"".substr($file, $pos+4);
$pos =strpos($file,"path d");
$file = substr($file, 0, $pos+4)." id=\"border\" ".substr($file, $pos+5);
$pos =strpos($file,"path d");
$file = substr($file, 0, $pos+4)." id=\"back\" ".substr($file, $pos+5);
$pos =strpos($file,"path d");
$file = substr($file, 0, $pos+4)." id=\"ghost\" ".substr($file, $pos+5);
echo $file;
}
?>
I am using the PHP script because it inserts the necessary id and class tags to do DOM manipulations. Parts of the snapcode can be modified using the id below
Name | id or class |
---|---|
Snapcode | #tag |
Ghost | .ghost |
Code | .back |
Frame | .border |
To read about scan guidelines, you can read Snapchat's Snapcode Scan Guidelines
You can put a gif instead of an image. You can fiddle around with the code on this codepen
The only limitation of this project at the moment is that Snapcodes cannot be downloaded from an iOS device. This is due to the canvas rendering used to convert from SVG to PNG. This is not a problem on Android devices or desktop. I will try to use a php script to convert the SVG to PNG if the user is on iOS.
- iOS download
- Ability to insert a picture inside the ghost
- custom sizes
- animated snapcodes (like the one pictured above)
- Snapchat - Snapcode API
- jscolor - Javascript Color Picker
- StackOverflow - Valuable help 😄