【发布时间】:2012-08-31 07:19:40
【问题描述】:
当我创建以下绘图时,我在绘图区域和轴之间得到了不需要的空间(即蓝色框和 x 轴之间的空白区域。如何删除这个空间并使绘图区域与绘图轴齐平? 谢谢。
xleft<-c(1,2,2.5)
xright<-c(2,2.5,2.75)
ybottom<-c(1,2,2.5)
ytop<-c(2,2.5,2.75)
par(mar = c(15,15,2.75,2.75) + 0.1)
plot(c(1,2.75),c(1,2.75),type="n",main="title",xlab="site.x",ylab="ylab")
rect(xleft,ybottom,xright,ytop,col=c("blue","red","green"))
#Label position along axes
x.label.position<-(xleft+xright)/2
y.label.position<-(ybottom+ytop)/2
#Labels
x.label<-c("Long species Name1","Long species Name2","Long species Name3")
y.label<-c("Long species Name4","Long species Name5","Long species Name5")
text(par()$usr[1]-0.5,y.label.position,y.label,xpd=TRUE,adj=1)
text(y=par()$usr[3]-0.5,x=x.label.position,x.label,xpd=TRUE,adj=1,srt=90)
par(xpd=TRUE)
legend(-0.1,0,legend=c("Species A","Species B","Species C"),fill=c("blue", "red", "green"))
更新 我用我的实际数据尝试了 plannapus 的建议,但只能让 y 轴表现出来,这段代码中是否还有其他一些东西在绘图区域的两侧增加了空间?
quartz("colour.plot")
par(mar=c(15,15,4,2)+0.1)#sets margins of plotting area
#create the data plot
plot(c(0,100), c(0,100), type = "n", main = paste(x,"vs",y," -",depth),xlab=paste("Species composition in remainder ",x),ylab=paste("Species composition in remainder ",y),asp=1,xaxs="i",yaxs="i")
#Add the rectangles
rect(mdf$xleft,mdf$ybottom,mdf$xright,mdf$ytop,col=mdf$colour)
生产
【问题讨论】:
-
"在这段代码中是否还有一些其他的东西在绘图区域的两侧增加了空间?"是的:
asp=1。这样,您将强制 x 轴和 y 轴相等,这可能与您的绘图区域的大小冲突。 -
在调用
plot之前添加par(pty="s")应该会强制绘图区域为正方形(因此"s")而不是图像上的矩形,因此更正asp“故障"。 -
我认为您应该选择@plannapus 答案,或者简单地设置
xlim、ylim以匹配您要绘制的区域。尽管@Alan 的解决方案给出了正确的外观,但对于您想要在这里执行的操作而言,概念上并不正确。只能说“治标不治本”。