A Better Colour Picker

Developer
Size
18,308 Kb
Views
38,456

How do I make an a better colour picker?

Uses event.layerX & layerY so close your console if you're in Chrome!. What is a a better colour picker? How do you make a a better colour picker? This script and codes were developed by Tristan on 25 August 2022, Thursday.

A Better Colour Picker Previews

A Better Colour Picker - Script Codes HTML Codes

<!DOCTYPE html>
<html >
<head> <meta charset="UTF-8"> <title>A Better Colour Picker</title> <link rel="stylesheet" href="css/style.css">
</head>
<body> <h1>A better colour picker</h1>
<div id="page"> <label>Colour 1: </label><input type="text" class="cpicker" /><br /> <label>Colour 2: </label><input type="text" class="cpicker" /><br /> <label>Colour 3: </label><input type="text" class="cpicker" />
</div> <script src='http://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script> <script src="js/index.js"></script>
</body>
</html>

A Better Colour Picker - Script Codes CSS Codes

body { font-family: arial; font-size:75%; }
h1{font-size:24px;text-transform:uppercase}
.colour-picker-interface { position: absolute;	background: #333;	font-family: helvetica, arial, sans-serif;	font-size: 8px;	line-height: 16px;	width: 465px;	box-shadow: 2px 2px 5px #333;	border-radius: 3px;	left: 100px;	top: 100px;	padding: 5px 0 0 5px;
}
.rgb-label, .hex-label {	color: #999;	float: left;	clear: left;	width: 10px;	height: 12px;	line-height: 16px;	margin: 6px 0 0 0;
}
.rgb-input,.hex-input,.hsl-input{	height: 16px;	font-size: 10px;	line-height: 12px;	padding: 2px;	margin: 2px 0 0 4px;	float: left;	border: 1px solid #444;
}
.rgb-input,.hsl-input{width:20px;}
.hex-input{width:50px;}
.colour-picker-controls{	float: left;	width: 95px;	height: 255px;	margin: 0 5px 5px 0;
}
.colour-picker-palette-controls{float:left;width:360px;margin:0 5px 5px 0;}
.colour-picker-palette,.colour-picker-level{	background: #000;	float: left;	position: relative;	cursor: crosshair;
}	.colour-picker-palette{width:360px;height:256px;}	.colour-picker-level{width:360px;height:20px;}
.colour-picker-preview{	width: 95px;	height: 95px;	background: #000;	float: left;
}
.colour-picker-control-box{	margin: 0 5px 5px 0;	float: left;
}
.colour-picker-button{	position: absolute;	font-size: 10px;	line-height: 10px;	padding: 1px 5px 2px 5px;	border: 1px solid #333;	background: #333;	color: #eee;	outline: 0;	bottom: 5px;	right: 5px;
}
.colour-picker-button-cancel {	right: 45px;
}
.colour-picker-button:hover {	background: #444;	cursor: pointer;
}
.colour-picker-button:active{	background: #111;
}
.colour-picker-palette-indicator {	width:3px;	height:3px;	border-radius:5px;	border:1px solid #000;	position:absolute;	left: 186px;	top: 256px;	cursor:crosshair;
}
.colour-picker-level-indicator{	width: 3px;	height: 18px;	border: 1px solid #000;	position: absolute;	top: 261px;	left: 186px;	cursor: crosshair;
}

A Better Colour Picker - Script Codes JS Codes

(function( $ ){ $.fn.colourPicker = function( options ){	var settings = {	target: this,	setBg: true,	offset: 10	}	if( options ){	$.extend( settings, options );	}	var _el = this,	alive = false,	colour = {	rgb: { r: 0, g: 0, b: 0 },	hsl: { h: 0, s: 0, l: 0.5 },	hex: '808080'	},	conversion = {	rgb2hex: function(rgb){	var r = (rgb.r.toString(16).length < 2) ? '0' + rgb.r.toString(16) : rgb.r.toString(16);	var g = (rgb.g.toString(16).length < 2) ? '0' + rgb.g.toString(16) : rgb.g.toString(16);	var b = (rgb.b.toString(16).length < 2) ? '0' + rgb.b.toString(16) : rgb.b.toString(16);	return r+g+b;	},	hex2rgb: function(hex){	return {r:parseInt(hex.substring(0,2),16),g:parseInt(hex.substring(2,4),16),b:parseInt(hex.substring(4,6),16)};	},	hsl2rgb: function(hsl){	var r, g, b;	if(hsl.s == 0){	r = g = b = hsl.l;	}else{	function hue2rgb(p, q, t){	if(t < 0) t += 1;	if(t > 1) t -= 1;	if(t < 1/6) return p + (q - p) * 6 * t;	if(t < 1/2) return q;	if(t < 2/3) return p + (q - p) * (2/3 - t) * 6;	return p;	}	var q = hsl.l < 0.5 ? hsl.l * (1 + hsl.s) : hsl.l + hsl.s - hsl.l * hsl.s;	var p = 2 * hsl.l - q;	r = hue2rgb(p, q, hsl.h + 1/3);	g = hue2rgb(p, q, hsl.h);	b = hue2rgb(p, q, hsl.h - 1/3);	}	return {r:parseInt(r*255),g:parseInt(g*255),b:parseInt(b*255)};	},	rgb2hsl: function(rgb){	var r = rgb.r / 255, g = rgb.g / 255, b = rgb.b / 255;	var max = Math.max(r, g, b), min = Math.min(r, g, b);	var h, s, l = (max + min) / 2;	if(max == min){	h = s = 0; // achromatic	}else{	var d = max - min;	s = l > 0.5 ? d / (2 - max - min) : d / (max + min);	switch(max){	case r: h = (g - b) / d + (g < b ? 6 : 0); break;	case g: h = (b - r) / d + 2; break;	case b: h = (r - g) / d + 4; break;	}	h /= 6;	}	return {h:h,s:s,l:l};	},	},	methods = {	initialise: function(target){	if( alive ) methods.destroy();	var colourPickerInterface = '<div class="colour-picker-interface">'	+'<div class="colour-picker-palette-controls">'	+'<canvas class="colour-picker-palette" width="360" height="256" id="canvas-palette"></canvas>'	+'<canvas class="colour-picker-level" width="360" height="20" id="canvas-level"></canvas>'	+'<div class="colour-picker-palette-indicator" id="palette-indicator">&nbsp;</div><div class="colour-picker-level-indicator" id="level-indicator">&nbsp;</div>'	+'</div>'	+'<div class="colour-picker-controls">'	+'<div class="colour-picker-rgb colour-picker-control-box">'	+'<label for="r" class="rgb-label">R:</label><input id="r" class="rgb-input" type="text" maxlength="3" value="0" maxvalue="255" minvalue="0" />'	+'<label for="g" class="rgb-label">G:</label><input id="g" class="rgb-input" type="text" maxlength="3" value="0" maxvalue="255" minvalue="0" />'	+'<label for="b" class="rgb-label">B:</label><input id="b" class="rgb-input" type="text" maxlength="3" value="0" maxvalue="255" minvalue="0" />'	+'</div>'	+'<div class="colour-picker-hsl colour-picker-control-box">'	+'<label for="h" class="rgb-label">H:</label><input id="h" class="hsl-input" type="text" maxlength="3" value="0" maxvalue="359" minvalue="0" />'	+'<label for="s" class="rgb-label">S:</label><input id="s" class="hsl-input" type="text" maxlength="3" value="0" maxvalue="255" minvalue="0" />'	+'<label for="l" class="rgb-label">L:</label><input id="l" class="hsl-input" type="text" maxlength="3" value="0" maxvalue="100" minvalue="0" />'	+'</div>'	+'<div class="colour-picker-hex colour-picker-control-box">'	+'<label for="hex" class="hex-label">#</label><input id="hex" class="hex-input" type="text" maxlength="6" value="000000" />'	+'</div>'	+'<div class="colour-picker-preview colour-picker-control-box"></div>'	+'<input type="button" id="colour-picker-cancel" class="colour-picker-button colour-picker-button-cancel" value="Cancel" /><input type="button" id="colour-picker-pick" class="colour-picker-button colour-picker-button-pick" value="Pick" />'	+'</div>'	+'</div>';	$('body').append(colourPickerInterface);	if( target.val() ){	colour = {	rgb: { r: 0, g: 0, b: 0 },	hsl: { h: 0, s: 0, l: 0 },	hex: target.val().replace( /#/, '' )	}	colour.rgb = conversion.hex2rgb(colour.hex);	colour.hsl = conversion.rgb2hsl(colour.rgb);	if( colour.hsl.l < 0.5 ){	$('#level-indicator, #palette-indicator').css({borderColor: '#ffffff'});	} else {	$('#level-indicator, #palette-indicator').css({borderColor: '#000000'});	}	$('#level-indicator').css({left: colour.hsl.l*359});	$('#palette-indicator').css({left: (colour.hsl.h * 359), top: (256 - (colour.hsl.s*256))});	} else {	colour = {	rgb: { r: 0, g: 0, b: 0 },	hsl: { h: 0, s: 0, l: 0.5 },	hex: '808080'	}	}	$('.rgb-input, .hex-input, .hsl-input').change(function(e){	switch(e.currentTarget.className){	case 'rgb-input':	if(parseInt(e.currentTarget.value) > e.currentTarget.attributes['maxvalue'].value){	e.currentTarget.value = e.currentTarget.attributes['maxvalue'].value;	}else if(parseInt(e.currentTarget.value) < e.currentTarget.attributes['minvalue'].value){	e.currentTarget.value = e.currentTarget.attributes['minvalue'].value;	}	colour.rgb.r = parseInt($('#r').val());	colour.rgb.g = parseInt($('#g').val());	colour.rgb.b = parseInt($('#b').val());	colour.hex = conversion.rgb2hex(colour.rgb);	colour.hsl = conversion.rgb2hsl(colour.rgb);	break;	case 'hex-input':	if( e.currentTarget.value.match( /[0-9a-fA-F]{6}/ ) ){	colour.hex = e.currentTarget.value;	colour.rgb = conversion.hex2rgb(colour.hex);	colour.hsl = conversion.rgb2hsl(colour.rgb);	}	break;	case 'hsl-input':	if( e.currentTarget.value > e.currentTarget.attributes['maxvalue'].value ){	e.currentTarget.value = e.currentTarget.attributes['maxvalue'].value;	}else if( e.currentTarget.value < e.currentTarget.attributes['minvalue'].value ){	e.currentTarget.value = e.currentTarget.attributes['minvalue'].value;	}	colour.rgb = conversion.hsl2rgb(colour.hsl);	colour.hex = conversion.rgb2hex(colour.rgb);	break;	}	methods.updatepreview();	});	$('.colour-picker-palette').bind( 'mousedown', function(e){	$('#palette-indicator').bind( 'mouseup', function(){	$('.colour-picker-palette').unbind( 'mousemove' );	});	$(this).bind( 'mousemove', function(e){	colour.hsl.h = (1/359) * e.originalEvent.layerX;	colour.hsl.s = 1-((1/256) * e.originalEvent.layerY);	colour.rgb = conversion.hsl2rgb( colour.hsl );	colour.hex = conversion.rgb2hex( colour.rgb );	$('#palette-indicator').css({ left: e.originalEvent.layerX, top: e.originalEvent.layerY });	methods.updatepreview();	return false;	});	return false;	}).bind( 'mouseup', function(){ $(this).unbind( 'mousemove' ); });	$('.colour-picker-level').bind( 'mousedown', function(e){	$('#level-indicator').bind( 'mouseup', function(){ $('.colour-picker-level').unbind( 'mousemove' ); });	$(this).bind( 'mousemove', function(e){	colour.hsl.l = e.originalEvent.layerX/359;	colour.rgb = conversion.hsl2rgb(colour.hsl);	colour.hex = conversion.rgb2hex(colour.rgb);	methods.changelevel(colour.hsl.l);	$('#level-indicator').css({ left: e.originalEvent.layerX+5 });	methods.updatepreview();	return false;	});	return false;	}).bind( 'mouseup', function(){ $(this).unbind( 'mousemove' ); });	$('#colour-picker-pick').bind( 'mouseup', function(){ methods.pickcolour(target); });	$('#colour-picker-cancel').bind( 'mouseup', function(){ methods.destroy(); });	$('.colour-picker-interface').css({ left: target.offset().left + target.width() + settings.offset, top: target.offset().top });	methods.drawpalette();	methods.drawlevel();	methods.updatepreview();	alive = true;	},	pickcolour: function(target){	target.val('#'+colour.hex);	if(settings.setBg && colour.hsl.l < 0.5){	target.css({backgroundColor:'#'+colour.hex,color:'#ffffff'});	}else{	target.css({backgroundColor:'#'+colour.hex,color:'#000000'});	}	$('.colour-picker-interface').remove();	alive = false;	},	destroy: function(){	$('.colour-picker-interface').remove();	alive = false;	},	drawpalette: function(){	canvasPalette = document.getElementById('canvas-palette');	contextPalette = canvasPalette.getContext('2d');	paletteImg = new Image();	paletteImg.src = "";	paletteImg.onload = function(){contextPalette.drawImage(paletteImg,0,0);};	},	drawlevel: function(){	canvasLevel = document.getElementById('canvas-level');	contextLevel = canvasLevel.getContext('2d');	levelImg = new Image();	levelImg.src = "";	levelImg.onload = function(){contextLevel.drawImage(levelImg,0,0);};	},	changelevel: function(l){	if( l <= 0.5 ){	$('.colour-picker-palette-controls').css({backgroundColor: '#000000'});	$('.colour-picker-palette').css({opacity: l*2});	$('#level-indicator, #palette-indicator').css({borderColor: '#ffffff'});	} else {	$('.colour-picker-palette-controls').css({ backgroundColor: '#ffffff'});	$('.colour-picker-palette').css({opacity: Math.abs(1-(1/l))});	$('#level-indicator, #palette-indicator').css({borderColor: '#000000'});	}	},	updatepreview: function(){	$('.colour-picker-preview').css({backgroundColor: '#'+colour.hex});	$('#r').val(colour.rgb.r);	$('#g').val(colour.rgb.g);	$('#b').val(colour.rgb.b);	$('#h').val(colour.hsl.h*360);	$('#s').val(colour.hsl.s*256);	$('#l').val(colour.hsl.l*100);	$('#hex').val(colour.hex);	}	};	//startup	_el.click( function(e){	methods.initialise($(e.target));	});	};
})( jQuery );
$('.cpicker').colourPicker();
A Better Colour Picker - Script Codes
A Better Colour Picker - Script Codes
Home Page Home
Developer Tristan
Username sinthetyc
Uploaded August 25, 2022
Rating 3.5
Size 18,308 Kb
Views 38,456
Do you need developer help for A Better Colour Picker?

Find the perfect freelance services for your business! Fiverr's mission is to change how the world works together. Fiverr connects businesses with freelancers offering digital services in 500+ categories. Find Developer!

Tristan (sinthetyc) Script Codes
Create amazing captions with AI!

Jasper is the AI Content Generator that helps you and your team break through creative blocks to create amazing, original content 10X faster. Discover all the ways the Jasper AI Content Platform can help streamline your creative workflows. Start For Free!