我正在使用以下代码在R中绘制地图:
library(maps)
library(mapdata)
map('worldHires',c('UK'),
xlim=c(-10,-1),
ylim=c(56,59.5))
points(-5.65,56.7233,col=2,pch=18)
导致
如何向地图添加比例以及显示纬度和经度的围绕它的框?类似于:
答案 0 :(得分:4)
maps
包还有一个函数map.axes
和map.scales
。
library(maps)
library(mapdata)
map('worldHires',c('UK'), xlim=c(-10,-1),
ylim=c(56,59.5))
points(-5.65,56.7233,col=2,pch=18)
map.axes()
map.scale()
给你
如果您查看map.axes
的代码,就会发现它只是调用axis
和box
。一种方法是手动完成并调整标签。
library(maps)
library(mapdata)
m <- map('worldHires',c('UK'), xlim=c(-10,-1),
ylim=c(56,59.5), mar=c(4, 4, 4, 4))
points(-5.65,56.7233,col=2,pch=18)
xat <- pretty(m$range[1:2])
xlab <- paste0(xat, " E")
yat <- pretty(m$range[3:4])
ylab <- paste0(yat, " N")
box()
axis(1, at=xat, labels=xlab)
axis(2, las=TRUE, at=yat, labels=ylab)
axis(3, at=xat, labels=xlab)
axis(4, las=TRUE, at=yat, labels=ylab)
map.scale(y=59)
这会给你带调整标签的相同图片
或者使用@Pascal建议的raster::degreeLabels*
函数。
library(maps)
library(mapdata)
library(raster)
m <- map('worldHires',c('UK'), xlim=c(-10,-1),
ylim=c(56,59.5), mar=c(4, 4, 4, 4))
points(-5.65,56.7233,col=2,pch=18)
xat <- pretty(m$range[1:2])
xlab <- parse(text=degreeLabelsEW(xat))
yat <- pretty(m$range[3:4])
ylab <- parse(text=degreeLabelsNS(yat))
box()
axis(1, at=xat, labels=xlab)
axis(2, las=TRUE, at=yat, labels=ylab)
axis(3, at=xat, labels=xlab)
axis(4, las=TRUE, at=yat, labels=ylab)
map.scale(y=59)
答案 1 :(得分:3)
根据rengis回答:
library(maps)
library(mapdata)
library(GISTools)
library(raster)
map('worldHires',c('UK'), xlim=c(-10,-1), ylim=c(56,59.5))
points(-5.65,56.7233,col=2,pch=18)
maps::map.scale(-9.5,56.2)
axis(1, at = seq(-10,-2,2), parse(text=degreeLabelsEW(seq(-10,-2,2))))
axis(2, at = seq(56,59,1), parse(text=degreeLabelsNS(seq(56,59,1))))
north.arrow(-8.5, 59, 0.1, "N")
box()