palette()
## [1] "black" "red" "green3" "blue" "cyan" "magenta" "yellow" ## [8] "gray"
pie(rep(1,8), col=palette(), border = palette(), labels = palette(), main = "palette")
超過palette(rainbow(10))的顏色數量後,顏色會循環使用html
par(mfrow = c(1, 2),mai=c(0.1,0.1,0.5,0.1)) palette(rainbow(10)) pie(rep(1,20), col=palette(), border = palette(), labels = "", main = "palette(rainbow(10))") palette(gray(0:12 / 12)) pie(rep(1,12), col=palette(), border = palette(), labels = "", main = "palette(gray(0:8/12))")
改成palette默認的基本顏色,R重啓後會自動恢復函數
palette("default")
colors()含有657種顏色名稱spa
par(mfrow = c(1, 2),mai=c(0.1,0.1,0.5,0.1)) pie(rep(1,657), col=colors(), border = colors(), labels = "", main = "colors()") pie(rep(1,27), col=colors()[grep('red', colors())], border = colors()[grep('red', colors())], labels = "", main = "colors()[grep('red', colors())]")
pie(rep(1,3), col = c(rgb(1,0,0),rgb(0,1,0),rgb(0,0,1)))
將顏色名稱轉換爲RGB色彩code
col2rgb(c("blue", "yellow"))
## [,1] [,2] ## red 0 255 ## green 0 255 ## blue 255 0
par(mfrow = c(1, 2),mai=c(0.1,0.1,0.5,0.1)) hsv_seq <- seq(0.0, 1.0, by=1/30) pie(rep(1,30),col=hsv(hsv_seq, 1.0, 1.0),main="HSV(S=1,V=1)",labels="") ## hsv(hsv_seq, 1.0, 1.0)與rainbow(30)獲取的顏色相同 pie(rep(1,30), col = rainbow(30), labels = "", main = paste("rainbow",30))
將RGB色彩轉換爲HSV色彩htm
rgb2hsv(col2rgb("blue"))
## [,1] ## h 0.6666667 ## s 1.0000000 ## v 1.0000000
pie(rep(1,30), col = hcl(seq(0, 360, length = 30)), labels = "", main = "HCL")
R自帶的grDevices包有以下6個調色板,傳入獲取顏色的個數,就得到相應個數的顏色列表,gray()的參數需在[0,1]。排序
rainbow()、heat.colors()、terrain.colors()、topo.colors()、cm.colors()、gray()rem
par(mfrow = c(2, 3),mai=c(0.1,0.1,0.5,0.1)) pie(rep(1, 12), col = rainbow(12), labels = "", main = "rainbow") pie(rep(1, 12), col = heat.colors(12), labels = "", main = "heat") pie(rep(1, 12), col = terrain.colors(12), labels = "", main = "terrain") pie(rep(1, 12), col = topo.colors(12), labels = "", main = "topo") pie(rep(1, 12), col = cm.colors(12), labels = "", main = "cm") pie(rep(1, 12), col = gray(0:12 / 12), labels = "", main = "gray")
colorRamp()和colorRampPalette()均可用於創建顏色板。經過傳入但願的主要顏色如藍、紫,colorRamp()和colorRampPalette都返回一個函數。
兩者返回的函數區別爲:colorRamp()返回的函數像grey()同樣,入參爲[0,1]之間的數列,數列中數字個數即爲函數返回的顏色板色彩數。colorRampPalette()返回的參數則像rainbow()同樣,入參爲但願返回顏色板色彩的數量。並且經過下例可知,colorRampPalette()返回漸變顏色板函數,而colorRamp()返回對比顏色板函數。雖然都是用一樣的顏色,結果不一樣。get
par(mfrow = c(1, 2),mai=c(0.1,0.1,0.5,0.1)) b2p1 <- colorRampPalette(c("blue", "purple")) b2p2 <- colorRamp(c("blue", "purple")) pie(rep(1, 12), labels = "", col = b2p1(12), border = b2p1(12), main = "colorRampPalette") pie(rep(1, 12), labels = "", col = b2p2(seq(0, 1, len = 12)), border = b2p2(seq(0, 1, len = 12)), main = "colorRamp")
雖說RColorBrewer包中實際用到的就只有brewer.pal()函數,可是包中的兩個優勢使得其很是實用。一是,包中顏色板被劃分爲序列型(sequential)、離散型(diverging)、分類型(qualitative)這三種基本能知足統計做圖須要的類型;二是,顏色都比較協調。更多指引見其官網ColorBrewer。it
每一個系列顏色數量是固定的。ast
序列型顏色板適用於從低到高排序明顯的數據,淺色數字小,深色數字大。
library(RColorBrewer) display.brewer.all(type = "seq")
分類型顏色板比較適合區分分類型的數據。
display.brewer.all(type = "qual")
離散型顏色板適合帶「正、負」的,對極值和中間值比較注重的數據。
display.brewer.all(type = "div")
利用HSV和HCL建立本身想要的漸變色
par(mfrow = c(1, 2),mai=c(0.1,0.1,0.5,0.1)) hsv_seq <- seq(0.0, 1.0, by=1/30) pie(rep(1,30),col=hsv(hsv_seq, 1.0, 1.0),main="HSV(S=1,V=1)",labels="") pie(rep(1,30), col = hcl(seq(0, 360, length = 30)), labels = "", main = "HCL")