Search
 
SCRIPT & CODE EXAMPLE
 

JAVASCRIPT

hsv to rgb js

const err = Object.freeze(["Invalid param"]);
class CLR {
    HSV_RGB(hue, sat, val){
		//gaurd
		if(!this.equal([typeof(hue), typeof(sat), typeof(val), "number"]) || !this.range(sat, 0, 1, true) || !this.range(val, 0, 1, true) || !this.range(hue, 0, 360, true))
			throw err[0];

		//imp vars
		let chr = val * sat;
		let hue_p = hue / 60;
		let m = val - chr;
		let x = chr * (1 - this.abs(hue_p % 2 - 1))
		//return value
		var temp;
		//processing
		switch(true) {
			case this.range(hue_p, 0, 1, false) || (hue_p == 0):
				temp = {red: chr, green: x, blue: 0};
				break;
			case this.range(hue_p, 1, 2, false) || (hue_p == 1):
				temp = {red: x, green: chr, blue: 0};
				break;
			case this.range(hue_p, 2, 3, false) || (hue_p == 2):
				temp = {red: 0, green: chr, blue: chr};
				break;
			case this.range(hue_p, 3, 4, false) || (hue_p == 3):
				temp = {red: 0, green: x, blue: chr};
				break;
			case this.range(hue_p, 4, 5, false) || (hue_p == 4):
				temp = {red: x, green: 0, blue: chr};
				break;
			case this.range(hue_p, 5, 6, false) || (hue_p == 5):
				temp = {red: chr, green: 0, blue: x};
				break;
		}

		return {red: (temp.red + m) * 255, green: (temp.green + m) * 255, blue: (temp.blue + m) * 255};
		//parseInt(number, 10).toString(base) change base
	}

	//return absolute value
	abs(val){
		//gaurd
		if(typeof(val) != "number")
			throw err[0];

		if(val < 0)
			return -val;
		else
			return val;
	}

	//check whether all values are in range
	range(val, l_bnd, u_bnd, inclusive){
		if(inclusive) {
			if(val <= u_bnd && val >= l_bnd)
				return true;
		}else {
			if(val < u_bnd && val > l_bnd)
				return true;
		}
		return false;
	}

	//check whether elements of array are all equal
	equal(arr){
		for(let i = 1; i < arr.length; i++)
			if(arr[i] != arr[0])
				return false;
		return true;
	}
}
let colour = new CLR();
//console.log(colour.equal([typeof(250), typeof(0.5), typeof(0.3), "number"]))
console.log(colour.HSV_RGB(250, 0.5, 0.3));
Comment

PREVIOUS NEXT
Code Example
Javascript :: react native password qwerty 
Javascript :: hoe to find items in mongoose 
Javascript :: javascript load on error 
Javascript :: react random string 
Javascript :: get a nodes path alias 
Javascript :: add item or nothing array js 
Javascript :: broken image 
Javascript :: passing third parameter in context.commit vuejs 
Javascript :: javascript convert color string to rgb 
Javascript :: routing with django and react 
Javascript :: fetching coordinates from db to map 
Javascript :: how to implement useMemo inside react cntext api 
Javascript :: index wise print elemnet in javascript 
Javascript :: devexpress image collection 
Javascript :: nested object 
Javascript :: firebase hosting rewrite function You need to enable JavaScript to run this app. 
Javascript :: javascript to typescript converter 
Javascript :: count repeated characters in a string in react 
Javascript :: @typescript-eslint/no-empty-function 
Javascript :: how to get the first element in an array in javascript 
Javascript :: react three fiber set cursor pointer 
Javascript :: Plumasil - new item button desc text 
Javascript :: for (i = 0; i < N; i++) for (j = 0; j < N; j++) { .... some O(1) code ... } 
Javascript :: jsf localdate converter 
Javascript :: How to pass variables from one page to another with AngularJS 
Javascript :: angularjs New Entry Not reflacting in table after inserting New record in CRUD angular app 
Javascript :: when selecting second dropdown ng-model object return null 
Javascript :: How to make notifications vibrate phone react native expo 
Javascript :: I have a dataframe with a json substring in 1 of the columns. i want to extract variables and make columns for them 
Javascript :: remember me option in firebase + react 
ADD CONTENT
Topic
Content
Source link
Name
4+3 =