我試圖在地圖上使用名稱有條件地爲城市標記點。如何使用ggmap有條件地在城市地圖中添加標籤
數據
name |s Latitude |s Longitude |s Frequency
Pelham Bay Park | 40.865556 | -73.808333 | 32
Greenbelt | 40.58846 | -74.139073 | 10
Van Cortlandt Park | 40.8978 | -73.8839 | 3
Flushing Meadows–Corona Park | 40.745833 | -73.844722 | 5
Central Park | 40.783333 | -73.966667 |22
代碼
library(ggmap)
town <- get_map(location = "New York", zoom = 10)
mapPoints <- ggmap(town) +
geom_point(aes(x = work_count$Longitude, y = work_count$Latitude, size = work_count$Frequency), data = work_count, alpha = .5) +
geom_text(aes(label=ifelse(work_count$Frequency>quart(work_count$Frequency)[2],as.character(work_count$name),'')),hjust=0,vjust=0)
quart <- function(x) {
x <- sort(x)
n <- length(x)
m <- (n+1)/2
if (floor(m) != m) {
l <- m-1/2; u <- m+1/2
} else {
l <- m-1; u <- m+1
}
c(Q1=median(x[1:l]), Q3=median(x[u:n]))
}
mapPoints
我得到以下錯誤: 錯誤:美學必須是長度爲1或相同的數據(5) :標籤,x,y 任何幫助表示讚賞
它更容易幫助您繪製的問題,如果你提供一個[重複的例子(http://stackoverflow.com/questions/5963269/how-to-make-a-great- r-reproducible-example)與樣本輸入數據,因此我們可以運行您的代碼來查看錯誤並測試可能的解決方案。 – MrFlick
您可能希望預處理標籤,而不是在'geom_text'中即時計算它們,即'work_count $ labels < - ifelse(work_count $ Frequency> quart(work_count $ Frequency)[2],as.character(work_count $ name),''))',然後將其傳遞給'geom_text'。 –
@黃偉煌我已經完成了一個專欄,只有符合我的標準的條目才存在,剩下的都是空的。然後我將work_count $標籤傳遞給geom_text中的標籤字段,但無法獲得輸出結果 –