Load all packages and libraries
install.packages('rasterVis')
install.packages('tmap')
install.packages('tigris')
install.packages('rgdal', type = "source", configure.args=c('--with-proj-include=/Library/Frameworks/PROJ.framework/Headers', '--with-proj-lib=/Library/Frameworks/PROJ.framework/unix/lib'))
install.packages("tmaptools")
install.packages("sf")
install.packages("leaflet")
library(sp)
library(tmap)
library(raster)
library(RColorBrewer)
library(classInt)
library(rasterVis)
library(tigris)
library(rgdal)
library("tmaptools")
library("sf")
library("leaflet")
Viz1: Create Ventura and LA County baselayer maps. I used library(tigris) to download LA and Ventura county census tract boundaries.Then I downloaded census level median home value data from American Factfinder. The last step was to use the merge function to join the census level data to the empty county boundaries. After that is was just all about fine-tuning the map. The interactive mapping mode fixes the problem of overcrowding the map.
Map1
legend.postion is used for plot mode. Use view.legend.position in tm_view to set the legend position in view mode.
legend.postion is used for plot mode. Use view.legend.position in tm_view to set the legend position in view mode.
Viz2: Add Hill and Woolsey Fire extent. For Viz2, I thought it would be interesting to add the extents of the Woosley fire to see the type of homes that were being affected by the fire. This could also be helpful in channeling recovery efforts since it would allow aid to be distributed to lower value housing areas first (assuming that’s the goal). For anyone interested: I had to scour the far reaches of the internet to find a downloadable fire extent data, not sure why it’s so hard. But I eventually found this google map: https://www.google.com/maps/d/u/0/viewer?mid=1IkW-WhQoRcP4WGIIP-h_v6WK8zb0jG3M&ll=34.126688966793836%2C-118.7345541136649&z=11. Then I downloaded a KML version of the extents then converted it using an online converter: https://mygeodata.cloud/conversion. This was all done outside of R but I figured this method was more realistic of a workflow I’d have outside this class.
Map1+
tm_shape(fire) +
tm_fill(col = "Name", alpha = 0.8, palette = "OrRd", title = "Name of Fire") +
tm_borders(alpha=0.5, lwd = 2, col = "red")+
tm_scale_bar()
legend.postion is used for plot mode. Use view.legend.position in tm_view to set the legend position in view mode.
legend.postion is used for plot mode. Use view.legend.position in tm_view to set the legend position in view mode.
Viz3: Recreating GEOG7 Map. I thought it would be a good exercise to try to recreate one of the earlier maps I did for GEOG7 on R since it’ll be good practice for manipulating map elements plus it was kinda fun and nostalgic for me.

*It’s not quite exact as the reference: https://imgur.com/Mk6rozp but I think I got pretty close.
---
title: "Spatial Mapping in R"
output: html_notebook
---
Load all packages and libraries
```{r}
install.packages('rasterVis')
install.packages('tmap')
install.packages('tigris')
install.packages('rgdal', type = "source", configure.args=c('--with-proj-include=/Library/Frameworks/PROJ.framework/Headers', '--with-proj-lib=/Library/Frameworks/PROJ.framework/unix/lib'))
install.packages("tmaptools")
install.packages("sf")
install.packages("leaflet")
library(sp)
library(tmap)
library(raster)
library(RColorBrewer)
library(classInt)
library(rasterVis)
library(tigris)
library(rgdal)
library("tmaptools")
library("sf")
library("leaflet")
```

Viz1: Create Ventura and LA County baselayer maps. I used library(tigris) to download LA and Ventura county census tract boundaries.Then I downloaded census level median home value data from American Factfinder. The last step was to use the merge function to join the census level data to the empty county boundaries. After that is was just all about fine-tuning the map. The interactive mapping mode fixes the problem of overcrowding the map. 
```{r}
##################Viz1: Ventura & LA Median Home Value Map##################
#pull ventura & LA county boundary map from library(tigris)
Ven_bound <- tracts(state = "CA", county = "Ventura", cb = TRUE)

LA_bound <- tracts(state = "CA", county = "Los Angeles", cb = TRUE)


#import csv file with median home value data (Ventura)
HW4 <- file.path ("/Users/krgr.df/Desktop/GEOG208/Assignment 4/ventura_median_val.csv")
median.val <- read.csv(HW4, stringsAsFactors = FALSE)
median.val$median.value <- as.numeric(median.val$median.value)
median.val$id2 <- as.character(median.val$id2)

#import csv file with median home value data (Los Angeles)
HW4.2 <- file.path ("/Users/krgr.df/Desktop/GEOG208/Assignment 4/LA_median_val.csv")
LA.median.val <- read.csv(HW4.2, stringsAsFactors = FALSE)
LA.median.val$median.val <- as.numeric(LA.median.val$median.val)
LA.median.val$id2 <- as.character(LA.median.val$id2)

#merge census tract boundaries with median home values (Ventura)
ven_merge <- merge(Ven_bound, median.val, by.x = "AFFGEOID", by.y = "id")

#merge census tract boundaries with median home values (Los Angeles)
LA_merge <- merge(LA_bound, LA.median.val, by.x = "AFFGEOID", by.y = "id")

#view histogram to find ideal breaks
hist(ven_merge@data$median.value)
hist(LA_merge@data$median.val)

#create map
tmap_mode("view")
tmap_style("cobalt")
Map1 <- tm_shape(ven_merge)+
  tm_fill(col = "median.value", palette = "PuBu", title = "Ventura County Median Home Value", 
          style = "fixed",
          breaks = c(0, 250000, 500000, 750000, 1000000, Inf),
          textNA = "No Data", 
          colorNA = "gray") +
  tm_borders(col = "white") +
  tm_layout(legend.title.size = 1,
            legend.text.size = 0.6,
            legend.text.color = "gray20",
            legend.position = c("left","bottom"),
            legend.bg.color = "white",
            legend.width = -1,
            legend.bg.alpha = 1)+
  tm_view(view.legend.position = c("right", "bottom")) +
tm_shape(LA_merge)+
  tm_fill(col = "median.val", palette = "YlGn", title = "LA County Median Home Value", 
          style = "fixed",
          breaks = c(0, 250000, 500000, 750000, 1000000, Inf),
          textNA = "No Data", 
          colorNA = "gray") +
  tm_borders(col = "white") +
  tm_layout(legend.title.size = 1,
            legend.text.size = 0.6,
            legend.text.color = "gray20",
            legend.position = c("left","bottom"),
            legend.bg.color = "white",
            legend.width = -1,
            legend.bg.alpha = 1) +
  tm_view(view.legend.position = c("left", "bottom"))

Map1
```

Viz2: Add Hill and Woolsey Fire extent. For Viz2, I thought it would be interesting to add the extents of the Woosley fire to see the type of homes that were being affected by the fire. This could also be helpful in channeling recovery efforts since it would allow aid to be distributed to lower value housing areas first (assuming that's the goal). 
For anyone interested:
I had to scour the far reaches of the internet to find a downloadable fire extent data, not sure why it's so hard. But I eventually found this google map: https://www.google.com/maps/d/u/0/viewer?mid=1IkW-WhQoRcP4WGIIP-h_v6WK8zb0jG3M&ll=34.126688966793836%2C-118.7345541136649&z=11. Then I downloaded a KML version of the extents then converted it using an online converter: https://mygeodata.cloud/conversion. This was all done outside of R but I figured this method was more realistic of a workflow I'd have outside this class.

```{r}
##################Viz2: Woosley Fire Extent##################
fire <- readOGR("/Users/krgr.df/Desktop/GEOG208/Assignment 4/test_shp/fire_KML/mygeodata", "Four_fires-polygon")

Map1+
tm_shape(fire) +
  tm_fill(col = "Name", alpha = 0.8, palette = "OrRd", title = "Name of Fire") +
  tm_borders(alpha=0.5, lwd = 2, col = "red")+
  tm_scale_bar()
```

Viz3: Recreating GEOG7 Map. I thought it would be a good exercise to try to recreate one of the earlier maps I did for GEOG7 on R since it'll be good practice for manipulating map elements plus it was kinda fun and nostalgic for me.
```{r}
yolo <- readOGR("/Users/krgr.df/Desktop/GEOG208/Assignment 4/yolo_shp","yolo_shp")
plot(yolo)
yolo@data$DEC_10_S_3 <- as.numeric(yolo@data$DEC_10_S_3)

#converting CRS, did no
yolo <- spTransform(yolo, CRS("+proj=longlat +datum=NAD83"))

ttm()
tmap_style("white")
tm_shape(yolo)+
  tm_fill(col = "DEC_10_S_3", palette = "Greens",
          style = "fixed",
          breaks = c(5, 37, 86, 151, 236, 371),
          title = "Filipino Population") +
  tm_borders() +
  tm_layout(frame = "#915812",
            frame.lwd = 4,
            legend.position = c(0.04, 0.2),
            legend.text.color = "#CF9752",
            legend.width = 1,
            legend.title.size = .9,
            title.position = c("center", "top"),
            main.title = "Yolo County U.S. Census",
            main.title.position = c("center", "top"),
            main.title.color = "#CF9752",
            fontface = 2,
            legend.frame = "#915812") +
  tm_credits("Norman Dela Fuente   05|20|2016", 
             col = "#CF9752", 
             position = .3)
```
*It's not quite exact as the reference: https://imgur.com/Mk6rozp but I think I got pretty close.
