Skip to content

Instantly share code, notes, and snippets.

@nguyenvanduocit
Last active August 28, 2019 12:25
Show Gist options
  • Save nguyenvanduocit/804782f28c02e8de375d to your computer and use it in GitHub Desktop.
Save nguyenvanduocit/804782f28c02e8de375d to your computer and use it in GitHub Desktop.
Color Thief Example
<!doctype html>
<html class="no-js" lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title>Color Thief</title>
<meta name="description" content="Get the dominant color or color palette from an image.">
<meta name="author" content="Lokesh Dhakar">
<meta name="viewport" content="width=device-width,initial-scale=1">
<style>
html, body{
margin: 0;
padding: 0;
}
*{
box-sizing: border-box;
}
#colorList{
padding: 10px;
text-align: center;
}
.section{
padding-top: 80px;
text-align: center;
width: 100%;
height: 600px;
padding:
}
.main-image{
width: 500px;
margin: 0 auto;
line-height: 0;
}
.color-block{
width:52px;
display:inline-block;
height:50px;
}
</style>
</head>
<body>
<div class="section">
<img class="main-image" src="image1.jpg" id="myImage" >
<div id="colorList"></div>
</div>
<div class="section">
<img class="main-image" src="image2.jpg" id="myImage" >
<div id="colorList"></div>
</div>
<div class="section">
<img class="main-image" src="image3.jpg" id="myImage" >
<div id="colorList"></div>
</div>
<div class="section">
<img class="main-image" src="image4.jpg" id="myImage" >
<div id="colorList"></div>
</div>
<script src="src/color-thief.js"></script>
<script src="examples/js/jquery.js"></script>
<script>
(function($){
$(document).ready(function(){
var colorThief = new ColorThief();
var sections = $('.section');
sections.each(function(){
var section = $(this);
var img = section.find("#myImage");
var colorList = section.find("#colorList");
var mainColor = colorThief.getColor(img[0]);
var color = "rgb("+mainColor[0] + "," + mainColor[1] + "," + mainColor[2] + ")";
img.parent().css("background-color",color);
var palette = colorThief.getPalette(img[0], 10);
for(var index = 0; index < palette.length; index++){
var color = "rgb("+palette[index][0] + "," + palette[index][1] + "," + palette[index][2] + ")";
colorList.append("<span class='color-block' style = 'background:"+color+"'></span>")
}
});
});
})(jQuery);
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment