Манипулирование «отсутствующей» меткой в ​​легенде: tmap - PullRequest
0 голосов
/ 11 октября 2019

Я хочу манипулировать надписью «Missing» в моей легенде.

img1

Я использую функцию tmap в R. Я хочу изменить ее на следующее: «Отсутствует или не подходит для джентрификации»

Я пытался использоватьфункция tm_text и рассмотрел, как я бы изменить метку в базовых данных, но не нашел решения. Также обратите внимание, что код использует функцию отображения.

########################
# categorical mapping function 
########################

cat.maps.wide.function <- function(data, varname, ltitle, colorplaette){
  tm_shape(data, unit = "mi") +
    tm_polygons(col = varname , # add variable(s)
                style = "cat", # set break pattern to object LQ.cuts
                palette = colorplaette,  # set color fill to blue refreshing
                border.col = "grey40", # color the borders white
                border.alpha = 0.5, # set border transparency
                title = ltitle, # title for legend
                colorNA = "white") + # color of missing data
    tm_style("bw") +
    tm_layout(panel.label.bg.color ="NA", 
              frame = FALSE, 
              bg.color = "transparent") + # panel label color
    tm_legend(legend.title.fontface = 2,  # legend bold
              legend.title.size = 0.75, 
              legend.text.size = 0.65, 
              legend.bg.alpha = 0, 
              legend.width = 5) + 
    tm_scale_bar(color.dark = "gray60", # Customize scale bar and north arrow
                 position = c(0.6, 0.05)) +  # set position of the scale bar
    tm_compass(type = "4star", 
               size = 2.5, # set size of the compass
               fontsize = 0.5, # set font size of the compass
               color.dark = "gray60", # color the compass
               text.color = "gray60", # color the text of the compass
               position = c(0.5, 0.05)) +  # set position of the compass

    # add border names
    tm_shape(boro.boundaries) + 
    tm_borders(alpha = .5) + 
    tm_text("boro", 
            size = 0.75, 
            remove.overlap = TRUE, 
            auto.placement=FALSE, 
            xmod= "x", ymod= "y") 

}

########################
# change in residential housing price
########################

# object for 2016 variable                                                 
mt1pva5.2016 <- cat.maps.wide.function(
  data = data.map.tract.wide,
  varname = "chgpcmt1pva5_overlap2016", 
  colorplaette = mt1pva5.overlap.colors, 
  ltitle = "Change in residential housing price for eligible tracts ")

mt1pva5.2016

Ответы [ 2 ]

0 голосов
/ 12 октября 2019

Спасибо за обмен данными. Видимо, вы можете использовать labels в tm_polygons, но не изменять значения NA. Для этого вам также понадобится textNA:

tm_polygons(col = varname , # add variable(s)
                style = "cat", # set break pattern to object LQ.cuts
                palette = colorplaette,  # set color fill to blue refreshing
                border.col = "grey40", # color the borders white
                border.alpha = 0.5, # set border transparency
                title = ltitle, # title for legend
                colorNA = "white", # color of missing data
                textNA = "Missing or not eligible to gentrify",
                labels = c("Decrease in residential housing price", 
                           "Increase in residential housing price")) +
...

tmap with custom label for NA

0 голосов
/ 11 октября 2019

функция tm_layout () имеет аргумент метки , который позволяет манипулировать меткой легенды, передающей символьный вектор. В youtm_layout добавьте что-то вроде:

tm_layout(labels = c("Decrease in residential housing price", 
                     "Increase in residential housing price", 
                     "Missing or not eligible to gentrify")
...