R/read.geoShape.R

Defines functions read.geoShape

Documented in read.geoShape

##' @title Read geoshape file into R
##'
##' @description Function for reading geojson shape file into R, come out to be a SpatialPolygonsDataFrame object
##'
##' @usage
##' read.geoShape(txt)
##'
##' @param txt   a JSON string, URL or file
##'
##' @examples
##' if(require(sp)){
##'   filePath = system.file("geojson/china.json",package = "leafletCN")
##'   map = read.geoShape(filePath)
##'   plot(map)
##' }
##' @export
read.geoShape = function(txt){

  raw = jsonlite::fromJSON(txt)
  # Polygons part

  ployList = lapply(raw$features$geometry$coordinates, function(x){
    if(class(x) == "array"){
      a = as.vector(x)
      dim(a) = c(length(a)/2,2)
      # if(length(dim(x))==3){
      #   Sr = (sp::Polygon(x[1,,])
      # }else{
      #   Sr = sp::Polygon(x)
      # }
      Sr = sp::Polygon(a)
      Sp = sp::Polygons(list(Sr), "namei")
      return(Sp)
    }else{
      if(any(sapply(x, class) == 'list')){
        whilei = 0
        while(any(sapply(x, class) == 'list')){
          whilei = whilei+1
          if(whilei==10)
            break
          index = which(sapply(x, class)=='list')[1]
          x = append(x[-index],x[[index]])
        }
      }

      Sr = lapply(x,function(y){

        a = as.vector(y)
        dim(a) = c(length(a)/2,2)
        return(sp::Polygon(a))
        # if(length(dim(y))==3){
        #   return(sp::Polygon(y[1,,]))
        # }else{
        #   return(sp::Polygon(y))
        # }
      })
      Sp = sp::Polygons(Sr, "namei")
      return(Sp)
    }
  })

  for(i in 1:length(ployList)){
    ployList[[i]]@ID = as.character(i)
  }
  ployPart =  sp::SpatialPolygons(ployList, 1:length(ployList))

  # dat part
  datPart = raw$features$properties
  if(any(sapply(datPart, class)=='list')){
    index = which(sapply(datPart, class)=='list')
    outlist = lapply(index, function(x){
      out = do.call(rbind,datPart[,x])
      colnames(out) = paste0(names(datPart)[x], 1:dim(out)[2])
      return(out)
    })
    datPart = cbind(datPart, do.call(cbind, outlist))
    datPart = datPart[, -index]
  }
  rownames(datPart) = row.names(ployPart)


  ex_1.7 = sp::SpatialPolygonsDataFrame(ployPart,
                                     datPart)
  return(ex_1.7)
}
Lchiffon/leafletCN documentation built on Jan. 31, 2024, 2:18 p.m.