Let me try to explain this then.

I have numbers like 

DataToPlot
          4         5         6
1 0.4454995 0.4462009 0.4286807
2 0.3761550 0.5423205 0.6500785
3 0.3779496 0.4671437 0.1799601


and I want to have a color legend with each color that is mapped to the 
following printed values

"1","0.9","0.8","0.7","0.6","0.5","0.4","0.3","0.2","0.1","0"

For making life easier I have rounded up my number to one digit so

  
matrixToPlot<-matrix(data=round(matrixToPlot,digits=1),nrow=nrow(matrixToPlot),ncol=ncol(matrixToPlot),dimnames=list(yLabel,
 xLabel))
matrixToPlot
    1   2   3
1 0.4 0.4 0.4
2 0.4 0.5 0.7
3 0.4 0.5 0.2


that indeed helps and makes the legend bar print the right values BUT there are 
not all the ranges printed there. So for the given example data set only the 
0.2, 0.3,0.4,0.5,0.6,0.7 are printed with the 0,0.1,0.8,0.9,1 missing.
Also I need some help to specify specific color to each of the given 
categories/ranges in the colorbar

my code now looks like


library(reshape2)
        library(ggplot2)
        
matrixToPlot<-matrix(data=runif(9),nrow=3,dimnames=list(seq(1,3),seq(4,6)))
    
matrixToPlot<-matrix(data=round(matrixToPlot,digits=1),nrow=nrow(matrixToPlot),ncol=ncol(matrixToPlot),dimnames=list(seq(1:3),
 seq(4:6)))
    tdm <- melt(matrixToPlot)
        cols<-colours()
        cols<-cols[1:(nrow(matrixToPlot)*ncol(matrixToPlot))]
        p<- ggplot(tdm, aes(x = Var2, y = Var1, fill = factor(value))) +
                  labs(x = "MHz", y = "Threshold", fill = "Duty Cycle") +
                  geom_raster(alpha=.5) +
                  scale_fill_discrete(h.start=1) +
                  scale_x_continuous(expand = c(0, 0)) +
                  scale_y_continuous(expand = c(0, 0)) 



Regards
Alex




________________________________
 From: Ista Zahn <istaz...@gmail.com>

Cc: R help <R-help@r-project.org> 
Sent: Thursday, February 21, 2013 2:15 PM
Subject: Re: [R] ggplot2 customizing a plot

Hi,


> Hello Ista,
[[elided Yahoo spam]]
>
> Your code is indeed an improvement.
>
> This is my code now and there are two things still missing.
>
> DataToPlot<-matrix(data=runif(9),nrow=3,dimnames=list(seq(1,3),seq(4,6)))
> require(reshape)
> require(ggplot2)
> require(raster)
>
>
> cols<-colours()
> cols<-cols[1:(nrow(DataToPlot)*ncol(DataToPlot))]
> tdm<-melt(DataToPlot)
>
> p<- ggplot(tdm, aes(x = Var2, y = Var1, fill = factor(value))) +
> labs(x = "MHz", y = "Threshold", fill = "Duty Cycle") +
> geom_raster(alpha=.5) +
> scale_fill_manual(values=cols,breaks=c("1","0.9","0.8","0.7","0.6","0.5","0.4","0.3","0.2","0.1","0"))

value looks like numbers, why are you converting it to a factor?

why this is how I found I should solve the problem......

>
> My values go from 0 to 1 (might go slightly over the limits) and I want to
> specify one color for the following ranges, 1, 0.9,0.8,.....,0 .  That means
> that values between the intervals will be "categorized" based on their
> closest match.

I don't really understand this.



> What I also tried is to create a gray scale pallete as this is printer
> friendly so the values from 0.9 to 0.1 get a greyish tone but I failed to do
> that with colours.

How about

ggplot(tdm, aes(x = Var2, y = Var1, fill = value)) +
  labs(x = "MHz", y = "Threshold", fill = "Duty Cycle") +
  geom_raster(alpha=.5) +
  scale_fill_gradient(low="gray90", high="black") +
  theme_bw()

>
> Could you please help me have both
> a. A fixed scale where values are categorized there
> and

Value is numeric, and trying to treat it like a category is only going
to make things difficult.

> b. a greyish pallete for the categories?

Use scale_fill_gradient with different shades of gray as the low and
high values, as shown above.

Best,
Ista

>
> I would like to thank you in advance for your reply
>
> Regards
> Alex
>
>
> ________________________________
> From: Ista Zahn <istaz...@gmail.com>

> Cc: R help <R-help@r-project.org>
> Sent: Wednesday, February 20, 2013 4:54 PM
> Subject: Re: [R] ggplot2 customizing a plot
>
> Hi,
>

>> Dear all,
>> I want some help improve my ggplot as following:
>> Make the plottable area with grid, so is easy one to see where each box
>> refers to x and y values.
>
> I don't think you can easily move the grid to the front, but you can
> make the tiles transparent so the grid can be seen through them by
> setting the alpha < 1.
>
>> Add a color bar but with fixed values, that I want to specify.
>
> use scale_fill_manual
>
>> How  I can do those two?
>
> p<- ggplot(tdm, aes(x = Var2, y = Var1, fill = factor(value))) +
>   labs(x = "MHz", y = "Threshold", fill = "Duty Cycle") +
>   geom_raster(alpha=.5) +
>   scale_fill_manual(values=c("red", "blue", "green", "purple",
> "orange", "pink", "tan", "violet", "yellow"))
>
>
> Best,
> Ista
>
>
>>
>> Before is some code what I have tried so far.
>>
>> Regards
>> Alex
>>
>>
>> DataToPlot<-matrix(data=seq(1:9),nrow=3,dimnames=list(seq(1,3),seq(4,6)))
>>
>>
>> require(reshape)
>> require(ggplot2)
>> require(raster)
>>
>>  tdm <- melt(DataToPlot)
>>
>>
>>
>> p<- ggplot(tdm, aes(x = Var2, y = Var1, fill = factor(value))) +
>>            labs(x = "MHz", y = "Threshold", fill = "Duty Cycle") +
>>            geom_raster() +
>>            scale_fill_discrete()
>>
>>        [[alternative HTML version deleted]]
>>
>>
>> ______________________________________________
>> R-help@r-project.org mailing list
>> https://stat.ethz.ch/mailman/listinfo/r-help
>> PLEASE do read the posting guide
>> http://www.R-project.org/posting-guide.html
>> and provide commented, minimal, self-contained, reproducible code.
>>
>
>
        [[alternative HTML version deleted]]

______________________________________________
R-help@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.

Reply via email to