2013-06-19 67 views
4

我最近從R-Bloggers.com的博文中瞭解到leafletjs.com。我希望實現的一個這樣的教程是用小冊子創建交互式地圖(http://leafletjs.com/examples/choropleth.html)。我一直使用R的rjson軟件包來創建data.js文件,以便通過傳單閱讀。儘管我已經成功地將所提供的形狀文件用作小冊子中的可讀JSON文件,但在嘗試將其他屬性從數據框(「data.csv」)合併到JSON文件時,我無法重複該過程;在這種情況下,我已經完成了rGIS以附加數據框中列出的每所學校罐頭數量的數據。我希望達到的目標是在小冊子中創建一個展示高中學區(由NAME變量標識)的等值線圖以及「罐」的總和。我相信這個問題是writeOGR將信息導出爲點而不是多邊形?R,GeoJSON和宣傳單

{ 
    "type": "Feature", 
    "properties": { 
     "name": "Alabama", 
     "density": 94.65 
    }, 
    "geometry": ... 
    ... 
} 

    ###load R scripts from dropbox 
    dropbox.eval <- function(x, noeval=F) { 
    require(RCurl) 
    intext <- getURL(paste0("https://dl.dropboxusercontent.com/",x), ssl.verifypeer = FALSE) 
    intext <- gsub("\r","", intext) 
    if (!noeval) eval(parse(text = intext), envir= .GlobalEnv) 
    return(intext) 
    } 

    ##pull scripts from dropbox 
    dropbox.eval("s/wgb3vtd9qfc9br9/pkg.load.r")  
    dropbox.eval("s/tf4ni48hf6oh2ou/dropbox.r") 

    ##load packages 
    pkg.load(c(ggplot2,plyr,gdata,sp,maptools,rgdal,reshape2,rjson)) 

    ###setup data frames 
    dl_from_dropbox("data.csv","dx3qrcexmi9kagx") 
    data<-read.csv(file='data.csv',header=TRUE) 

    ###prepare GIS shape and data for plotting 
    dropbox.eval("s/y2jsx3dditjucxu/dlshape.r")  
    temp <- tempfile() 
    dlshape(shploc="http://files.hawaii.gov/dbedt/op/gis/data/highdist_n83.shp.zip", temp) 
    shape<- readOGR(".","highdist_n83") #HDOE high school districts 
    [email protected] 

    shape2<- spTransform(shape, CRS("+proj=longlat +datum=NAD83")) 


    data.2<-ddply(data, .(year, schoolcode, longitude, latitude,NAME,HDist,SDist), summarise, 
      total = sum(total), 
      cans= sum(cans)) 


    ###merging back shape properties and data frame 
    coordinates(data.2) <-~longitude + latitude 
    [email protected]$id <- rownames([email protected]) 

    sh.df <- as.data.frame(shape2) 

    sh.fort <- fortify(shape2 , region = "id") 

    sh.line<- join(sh.fort, sh.df , by = "id") 



    mapdf <- merge(sh.line , data.2 , by.x= "NAME", by.y="NAME" , all=TRUE) 

    mapdf <- mapdf[ order(mapdf$order) , ] 


    ###exporting merged data frame as JSON 
mapdf.sp <- mapdf 
coordinates(mapdf.sp) <- c("long", "lat") 
writeOGR(mapdf.sp, "hssra.geojson","mapdf", driver = "GeoJSON") 

但是,看起來我的功能不斷重複。如何彙總功能信息,使其看起來更像以下內容:

var statesData = {"type":"FeatureCollection","features":[ 
{"type":"Feature","id":"01","properties":{"name":"Alabama","density":94.65}, 
"geometry":{"type":"Polygon","coordinates":[[[-87.359296,35.00118], 
[-85.606675,34.984749],[-85.431413,34.124869],[-85.184951,32.859696], 
[-85.069935,32.580372],[-84.960397,32.421541],[-85.004212,32.322956], 
[-84.889196,32.262709],[-85.058981,32.13674],[-85.053504,32.01077],[-85.141136,31.840985], 
[-85.042551,31.539753],[-85.113751,31.27686],[-85.004212,31.003013],[-85.497137,30.997536], 
[-87.600282,30.997536],[-87.633143,30.86609],[-87.408589,30.674397],[-87.446927,30.510088], 
[-87.37025,30.427934],[-87.518128,30.280057],[-87.655051,30.247195],[-87.90699,30.411504], 
[-87.934375,30.657966],[-88.011052,30.685351],[-88.10416,30.499135],[-88.137022,30.318396], 
[-88.394438,30.367688],[-88.471115,31.895754],[-88.241084,33.796253], 
[-88.098683,34.891641],[-88.202745,34.995703],[-87.359296,35.00118]]]}}, 


{"type":"Feature","id":"02","properties":{"name":"Alaska","density":1.264}, 
"geometry":{"type":"MultiPolygon","coordinates":[[[[-131.602021,55.117982], 
[-131.569159,55.28229],[-131.355558,55.183705],[-131.38842,55.01392], 
[-131.645836,55.035827],[-131.602021,55.117982]]],[[[-131.832052,55.42469], 
[-131.645836,55.304197],[-131.749898,55.128935],[-131.832052,55.189182], 
[-131.832052,55.42469]]],[[[-132.976733,56.437924],[-132.735747,56.459832], 
[-132.631685,56.421493],[-132.664547,56.273616],[-132.878148,56.240754], 
[-133.069841,56.333862],[-132.976733,56.437924]]],[[[-133.595627,56.350293], 
+0

感謝您的修改。它看起來更重要和乾淨。 :) – user2300643

回答

4

我最終解決了這個問題。

我基本上做的是基本上加入data.2 DF的形狀文件: ([email protected]<-join([email protected],data.2)

,然後以JSON格式(使用JSON的驅動程序)與* .js擴展使用rgdal包writeOGR。

我希望這可以幫助他人。