[Rd] new function: twotailed.colors {base}

Wolfram Fischer - Z/I/M wolfram@fischer-zim.ch
Fri Jan 24 10:25:23 2003


I suggest to add a new function to create a vector of
n ``contiguous'' colors with tails in two colors.
This function is similar to `cm.colors' but the colors
can be choosen by hsv values.

This function could be used e.g. as alternative to
the default ``col.regions'' in `levelplot'.

Perhaps the arguments in the following code could be 
simplified.

Wolfram Fischer

#--- twotailed.colors.R

twotailed.colors <-
function(
      n			= 7			# number of colors to be in the palette
	, n5		= n %% 2	# number of colors between the two tails
	, h1		= 0.02		# 0|1 = rot
	, h2		= 0.15		# 0.7 = blau, 0.15 = samtgelb, 0.35 = grün
	, s0		= 1			# saturation: begin and end
	, s5		= 1/n*1.4	# saturation: in the middle
	, v0		= 1			# value: begin and end
	, v5		= 1			# value: in the middle
	, s01		= s0		# beginning saturation of first tail
	, s02		= s0		# ending saturation of second tail
	, s51		= s5		# middle saturation on of first tail
	, s52		= s5		# middle saturation on of second tail
	, v01		= v0		# beginning value of first tail
	, v02		= v0		# ending value of second tail
	, v51		= v5		# middle value on of first tail
	, v52		= v5		# middle value on of second tail
	, n.tail	= ( n - n5 ) %/% 2
							# number of colors in each tail
	, s1		= seq( s01, s51, length = n.tail )
	, s2		= seq( s52, s02, length = n.tail )
	, v1		= seq( v01, v51, length = n.tail )
	, v2		= seq( v52, v02, length = n.tail )
){
	c(	hsv( h1, s1, v1 )
	,	rep( hsv( h1, round(s5,0), v5 ), n5 )
	,	hsv( h2, s2, v2 )
	)
}

#--- twotailed.colors.Rd

\name{twotailed.colors}
\alias{twotailed.colors}
\title{Two tailed color palette}
\description{
  Create a vector of \code{n} ``contiguous'' colors
  with tails in two colors.
}
\usage{
twotailed.colors( n = 7, n5 = n %% 2, h1 = 0.02, h2 = 0.15
	, s0 = 1, s5 = 1/n*1.4, v0 = 1, v5 = 1
	, s01 = s0, s02 = s0, s51 = s5, s52 = s5
	, v01 = v0, v02 = v0, v51 = v5, v52 = v5
	, n.tail = ( n - n5 ) %/% 2
	, s1 = seq( s01, s51, length = n.tail )
	, s2 = seq( s52, s02, length = n.tail )
	, v1 = seq( v01, v51, length = n.tail )
	, v2 = seq( v52, v02, length = n.tail )
	)
}
\arguments{
	\item{n}{ number of colors to be in the palette.}
	\item{n5}{ number of colors between the two tails.}
	\item{h1,h2}{values in the range \code{[0,1]} for the
		``hue'' of the color of each tail, e.g.:
		0 for red,
		0.15 for yellow,
		0.35 for green,
		0.7 for blue.}
	\item{s0}{ saturation: begin and end.}
	\item{s5}{ saturation: in the middle.}
	\item{v0}{ value: begin and end.}
	\item{v5}{ value: in the middle.}
	\item{s01}{ beginning saturation of the first tail.}
	\item{s02}{ ending saturation of the second tail.}
	\item{s51,s52}{ middle saturation on of the first and the second tail.}
	\item{v01}{ beginning value of the first tail.}
	\item{v02}{ ending value of the second tail.}
	\item{v51,v52}{ middle value on of the first and the second tail.}
	\item{n.tail}{ number of colors in each tail.}
	\item{s1,s2}{ vector of saturations of first and the second tail.}
	\item{v1,v2}{ vector of values of the first and the tail.}
}
\details{
}
\value{A character vector, \code{cv}, of color names.  This can be used
  either to create a user--defined color palette for subsequent
  graphics by \code{\link{palette}(cv)}, a \code{col=} specification
  in graphics functions or in \code{par}.
}
\seealso{
  \code{\link{cm.colors}},
  \code{\link{colors}}, \code{\link{palette}}, \code{\link{hsv}},
  \code{\link{rgb}}, \code{\link{gray}} and \code{\link{col2rgb}} for
  translating to RGB numbers.
}
\author{
	Wolfram Fischer
}
\examples{
twotailed.colors(12)
twotailed.colors(24,12)
showcolors( twotailed.colors(24,12) )

}
\keyword{color}
\keyword{dplot}

#---