Pixel Art.PY
data:image/s3,"s3://crabby-images/fe1ed/fe1ed40af6e69ed1d9566b1425d46476724bd382" alt="Pixel Art.PY"
I loved playing with Legos as a kid and I recently wanted to try them out again. One of the sets that caught my eye was an image remade with Legos
data:image/s3,"s3://crabby-images/6c53f/6c53fda6a5d63110f368d91f03ee91702c412c26" alt=""
I had recently seen a video where they paired NFC tags with album covers to play the album on nearby speakers. I thought it would be cool to replicate this idea for my favorite albums but use a pixelated covers made of Legos. After a little research I found an online marketplace for Legos where I could purchase the 1x1 bricks I needed. They cost less than $.01 / piece so I ordered ~5000 pieces of 20 different colors
data:image/s3,"s3://crabby-images/d7180/d7180b95bbbb96860f6b6e52796f94aa7eea9c6a" alt=""
I then entered the colors, color codes, and quantities into an excel sheet
data:image/s3,"s3://crabby-images/f02ef/f02ef0871acbe8dfa4f40c40b68b3516b7a671df" alt=""
I wanted to start with one of my favorite albums, 21 by Adele
data:image/s3,"s3://crabby-images/d9dd4/d9dd4bacbf1bb65cd85833add562887cf25959d3" alt=""
Next, I needed to turn this image into something I could build with my Legos. This would require two steps. First I would need to convert the image into the Lego colors I had and second I needed to pixelate the image. To achieve the first step I would look at each pixel and convert it to the nearest Lego color. After implementing this using the Pillow library, I found that using all 20 colors didn't produce the results I was looking for
data:image/s3,"s3://crabby-images/435d1/435d159fcd796f8853cabc4a08b3aaec9c457633" alt=""
The background of the original album is grey but depending on the shade of grey sometimes sometimes the program found brown was the closer color. To solve this I decided to reduce the number of colors I would use. I wasn't sure how many colors would produce the best results so I had the program randomly choose either 4, 8, or 16 colors and then repeated the process several time so I would have many options to choose from
#Set Variables
Image_Name = 'Adele'
Sample_Folder_Name = Image_Name + '_Sample'
Save_Name_Orginal = Image_Name + "_Original" + ".png"
Save_Name_Slice = Image_Name + "-%s.png"
Sample_Name = Sample_Folder_Name + "-%s.png"
k = 1 #Slice Number
Dir_Name = Image_Name
#Create Directory
try:
# Create target Directory
os.mkdir(Dir_Name)
os.mkdir(Dir_Name + "//" + Sample_Folder_Name)
print("Directory " , Dir_Name , " Created ")
except FileExistsError:
print("Directory " , Dir_Name , " already exists")
##########################################################################################
#Import Image
im=Image.open(Path)
for t in range(0,100):
img = im
Color_Option = ['4', '8', '16']
Num_Colors = numpy.random.choice(Color_Option, size=1)
Num_Colors = int(Num_Colors[0])
df = pd.read_csv(Path)
df = df['RGB']
df = df.str.split(",", expand = True)
df = df.reset_index(drop = True)
df = df.drop(3,1)
df_palette = df.sample(Num_Colors)
list_palette = df_palette.values.tolist()
x = ""
for i in list_palette:
x += " ".join(str(j) for j in i) + " "
x = x.split(" ")
while("" in x) :
x.remove("")
for i in range(0, len(x)):
x[i] = int(x[i])
palette = x
p_img = Image.new('P', (16, 16))
y = 256 / Num_Colors
y = int(y)
p_img.putpalette(palette * y)#The 16 is 256 / # of palette colors
conv = img.quantize(palette=p_img, dither=0)
try:
conv.save(os.path.join(Path,"%s" % Image_Name ,Sample_Folder_Name, Save_Name_Slice % t))
except:
pass
Python Code to Change the Pixel Color of the Album
This gave me some fun results. I now had the album in the same colors as my Legos
data:image/s3,"s3://crabby-images/3c53b/3c53b14ff7d096f37642fed9cc1bdb0de71f87ef" alt=""
data:image/s3,"s3://crabby-images/7b1c7/7b1c71e47b9fd60e209271d45f38a87b8aba8951" alt=""
data:image/s3,"s3://crabby-images/25f61/25f61a163a84043aa34a79443991e03cb4bbbbe5" alt=""
Different Color Palettes of 21 by Adele
The next step was to pixelate the photos. I found some 32x32 base plates I would attach the Legos to so I decided to go with 64x64 pixels and use four plates
#Pixelate Image
img = conv
img = img.resize((64,64),Image.BILINEAR)
#resize
o_size = (1000,1000) #output size
img = img.resize(o_size,Image.NEAREST)
img.save(os.path.join(Path,"%s" % Image_Name ,Sample_Folder_Name, Sample_Name % t))
t +=1
Python Code Converting Image Into 64x64 Pixels
I decided to choose the most accurate color option (Show Left Below) for this project but down the line I may go down a less photo realistic palette
data:image/s3,"s3://crabby-images/bfa7f/bfa7f9f9f436c22da05a51c353ece30f35d14e58" alt=""
data:image/s3,"s3://crabby-images/55fed/55feda86f9a25d2689c2ae8b06d6278d68342a11" alt=""
data:image/s3,"s3://crabby-images/13810/138106f63bd7a0d1b1eb304c08ddc77efdf121f2" alt=""
21 by Adele Pixelated
I now had a 64x64 pixel album cover in colors I also had in Legos. The next step was to separate the image into pieces to make it easier to read. I decided to go with 16 16x16 pixel images
###########Slice Image into 16 / 16 pixel###########
#Import Image
img = Image.open('Path')
imgwidth, imgheight = img.size
height = imgheight / 4
width = imgwidth / 4
for i in range(0,imgheight,int(height)):
for j in range(0,imgwidth,int(width)):
box = (j, i, j+width, i+height)
a = img.crop(box)
a = a.resize(o_size,Image.NEAREST)
try:
a.save(os.path.join(Path,"%s" % Image_Name,Save_Name_Slice % k))
except:
pass
k +=1
Python Code to Split Photo Into 16 Equal Pieces
data:image/s3,"s3://crabby-images/574e0/574e0d49bd04cf956a02705fafbd8576cc68e20a" alt=""
data:image/s3,"s3://crabby-images/b858f/b858f6c6a32d8a21110dc0e298061917aee9ba7c" alt=""
data:image/s3,"s3://crabby-images/d63f6/d63f660fa9f37db9d84830fedd1ed19d5bdf8443" alt=""
data:image/s3,"s3://crabby-images/7f919/7f9190897da4e5da50a80373c0539229def5b96b" alt=""
data:image/s3,"s3://crabby-images/cdb14/cdb145a85df7005e43cf20cfe8a13ce78df348cd" alt=""
data:image/s3,"s3://crabby-images/517b7/517b77cf494c8c4748aa9d9a4b36940f3a98ab2d" alt=""
data:image/s3,"s3://crabby-images/aee19/aee19aab80ac97f110d22bc6d8320c24549a438b" alt=""
data:image/s3,"s3://crabby-images/737d9/737d9595269737083b01135c59383e49e1eb1629" alt=""
data:image/s3,"s3://crabby-images/108bc/108bc68e162bc24624d699f6f4bfb297bc9fdba9" alt=""
Showing 9/16 Individual Pieces
I could now get started recreating the album cover
data:image/s3,"s3://crabby-images/8739c/8739cb6b22b8c308552fe5040c306c83ce66f782" alt=""
data:image/s3,"s3://crabby-images/ad6d3/ad6d3ed4d825cdf6dbc0c1c490256de6175955af" alt=""
data:image/s3,"s3://crabby-images/bb491/bb49101183abc35d9234095afecf5c5b99b696f3" alt=""
Lastly to be able to tap my phone on the album cover and play the album on speakers in the room I purchased some NFC (Near Field Communication) tags. I then used Apple's App Shortcuts to link the tag to the album. More information on this can be found in the below link.
data:image/s3,"s3://crabby-images/a9ddf/a9ddff7b6cc6f7cdebf0451c36897e6d226e8943" alt=""