1 Data Introduction

The data set used to create the visualization on this page was the Philly shooting data set. This data set has 15577 observations of 25 different variables. Missing variables were removed from the data set. The final data set has 15303 observations of 25 different variables.

shootings2 <- read.csv(file="https://isarenn.github.io/irennenberg/Week8/shootings.csv") #reading in the dataset from githbub


## Define objects with geo-coordinate system to plot specific information
race = st_as_sf(data.frame(x = -75.3677, y = 39.9168),
                coords = c("x", "y"),
                crs = 4326)
gender = st_as_sf(data.frame(x = -75.3477, y = 39.9168),
                coords = c("x", "y"),
                crs = 4326)
fatal = st_as_sf(data.frame(x = -75.3877, y = 39.9168),
                coords = c("x", "y"),
                crs = 4326)

shootings <- shootings2[complete.cases(shootings2),]

2 Philadelphia Shootings: Interactive Map

Below is the interactive map that aggregates/collapses information over the entirety of the city of Philadelphia. Circles are shown as red if the shooting was nonfatal, and blue if the shooting was fatal.

img1<-"https://isarenn.github.io/irennenberg/Week8/Gender.jpeg"
img2<-"https://isarenn.github.io/irennenberg/Week8/Race.jpeg"
img3<-"https://isarenn.github.io/irennenberg/Week8/Fatal.jpeg"

pal <- colorFactor(c("red", "blue"), domain = c("0", "1"))

Map1<-leaflet(shootings) %>%
  setView(lng=-75.15092, lat=40.00995, zoom = 11) %>%
  addProviderTiles(providers$CartoDB.Positron, group="Positron") %>%
  addProviderTiles(providers$CartoDB.PositronNoLabels, group="PositronLabels") %>%  
  addProviderTiles(providers$Esri.NatGeoWorldMap, group="Esri") %>%
  addMiniMap() %>%
  ## neighborhood boundary
  addPolygons(data = phillyNeighbor,
              color = 'lightpink',
              weight = 2)  %>%
  ## plot information on the map
  addCircleMarkers(data = shootings,
                   radius = ~ifelse(fatal == "1", 5, 3),
                   color = ~pal(fatal),
                   stroke = FALSE, 
                   fillOpacity = 0.5,
                   popup = ~popupTable(shootings),
                   clusterOptions = markerClusterOptions(maxClusterRadius = 40)) %>%
  addLayersControl(baseGroups = c('Positron', 'PositronLabel', 'Esri'),
                   overlayGroups = c("Shootings Data"),
                   options = layersControlOptions(collapsed = TRUE)) %>%
  addCircleMarkers(data = gender, 
                   color = "blue",
                   weight = 2,
                   label = "Gender",
                   stroke = FALSE, 
                   fillOpacity = 0.95,
                   group = "gender") %>%
  addPopupImages(img1, 
                  width = 300,
                  height = 300,
                  tooltip = FALSE,
                  group = "gender")  %>%
  addCircleMarkers(data = race, 
                   color = "purple",
                   weight = 2,
                   label = "Race",
                   stroke = FALSE, 
                   fillOpacity = 0.95,
                   group = "race") %>%
  addPopupImages(img2, 
                  width = 300,
                  height = 300,
                  tooltip = FALSE,
                  group = "race") %>%
  addCircleMarkers(data = fatal, 
                   color = "lightblue",
                   weight = 2,
                   label = "Fatality",
                   stroke = FALSE, 
                   fillOpacity = 0.95,
                   group = "fatal") %>%
  addPopupImages(img3, 
                  width = 300,
                  height = 300,
                  tooltip = FALSE,
                  group = "fatal")  

title<-tags$div(HTML('<font color = "purple" size =4><b>Philadelphia Shootings By Borough</b></font>'))


Map2<-Map1 %>%
  addControl(title, position="topleft")

Map2

3 Conclusions

From the pop-ups, we can see that the majority of the shootings involved men, and the most prevalent race was black. We can also see that the shootings were primarily non fatal. In addition, we see that the shootings are clustered in the majority of the inner portions of the city.

Thank you!

---
title: "Philadelphia Shootings Visualized With Maps"
author: "Isabelle Rennenberg"
output: 
  html_document: 
    code_folding: hide
    toc: true
    toc_float: true
    toc_collapsed: true
    toc_depth: 4
    theme: "spacelab"
    number_sections: true
    code_download: true
      
    
---  


<style type="text/css">

h1.title {
  font-size: 38px;
  color: #0000FF;
  text-align: center;
}
h4.author { /* Header 4 - and the author and data headers use this too  */
    font-size: 18px;
  font-family: "Times New Roman", Times, serif;
  color: #41b6c4;
  text-align: center;
}
h1 {
    font-size: 22px;
    font-family: "Times New Roman", Times, serif;
    color: #41b6c4;
    text-align: left;
}
</style>


```{r setup, include=FALSE}
# code chunk specifies whether the R code, warnings, and output 
# will be included in the output files.
if (!require("tidyverse")) {
   install.packages("tidyverse")
   library(tidyverse)
}
if (!require("knitr")) {
   install.packages("knitr")
   library(knitr)
}
if (!require("sf")) {
   install.packages("sf")
   library(sf)
}
if (!require("terra")) {
   install.packages("terra")
   library(terra)
}
if (!require("plotly")) {
   install.packages("plotly")
   library(plotly)
}
if (!require("dplyr")) {
   install.packages("dplyr")
   library(dplyr)
}
if (!require("png")) {
    install.packages("png")             
    library("png")
}
if (!require("spData")) {
    install.packages("spData")             
    library("spData")
}
if (!require("colourpicker")) {
    install.packages("colourpicker")              
    library("colourpicker")
}
if (!require("gifski")) {
    install.packages("gifski")              
    library("gifski")
}
if (!require("magick")) {
    install.packages("magick")              
    library("magick")
}
#if (!require("spDataLarge")) {
 #   install.packages("spDataLarge")              
  #  library("spDataLarge")
#}
### ggplot and extensions
if (!require("ggplot2")) {
    install.packages("ggplot2")              
    library("ggplot2")
}
if (!require("gganimate")) {
    install.packages("gganimate")              
    library("gganimate")
}
if (!require("tmap")) {
    install.packages("tmap")              
    library("tmap")
}
if (!require("sf")) {
    install.packages("sf")              
    library("sf")
}
if (!require("tigris")) {
    install.packages("tigris")              
    library("tigris")
}
if (!require("mapview")) {
    install.packages("mapview")              
    library("mapview")
}
if (!require("pander")) {
    install.packages("pander")              
    library("pander")
}
if (!require("lattice")) {
    install.packages("lattice")
library("lattice")
}
if (!require("sp")) {
    install.packages("sp")
library("sp")
}
if (!require("leaflet")) {
    install.packages("leaflet")
library("leaflet")
}
if (!require("leafpop")) {
    install.packages("leafpop")
library("leafpop")
}
if (!require("leafem")) {
    install.packages("leafem")
library("leafem")
}
#if (!require("spDataLarge")) {
 #   install.packages("spDataLarge", repos = "https://geocompr.r-universe.dev")
#library("spDataLarge")
if (!require("htmlwidgets")) {
    install.packages("htmlwidgets")
library("htmlwidgets")
}
if (!require("leaflet.extras")) {
    install.packages("leaflet.extras")
library("leaflet.extras")
}
if (!require("htmltools")) {
    install.packages("htmltools")
library("htmltools")
}
if(!require("png")){
  install.packages("png")
  library(png)
}
if(!require("viridis")){
  install.packages("viridis")
  library(viridis)
}
if(!require("ggmap")){
  install.packages("ggmap")
  library(ggmap)
}
if(!require("webshot")){
  install.packages("webshot")
  library(webshot)
}
if(!require("htmlwidgets")){
  install.packages("htmlwidgets")
  library(htmlwidgets)
}
if(!require("animation")){
  install.packages("animation")
  library(animation)
}
if(!require("gifski")){
  install.packages("gifski")
  library(gifski)
}
if(!require("htmlTable")){
  install.packages("htmlTable")
  library(htmlTable)
}
if(!require("magrittr")){
  install.packages("magrittr")
  library(magrittr)
}
### library(magrittr)
###
knitr::opts_chunk$set(echo = TRUE,       
                      warning = FALSE,   
                      results = TRUE,   
                      message = FALSE,
                      comment = NA)
```

# Data Introduction

The data set used to create the visualization on this page was the Philly shooting data set. This data set has 15577 observations of 25 different variables. Missing variables were removed from the data set. The final data set has 15303 observations of 25 different variables.


```{r, include=FALSE}

phillyNeighbor  <- st_read("https://pengdsci.github.io/STA553VIZ/w08/Neighborhoods_Philadelphia.geojson")
philly  <- st_read("https://pengdsci.github.io/STA553VIZ/w08/PhillyNeighborhood-blocks.geojson") # block level data

```

```{r}
shootings2 <- read.csv(file="https://isarenn.github.io/irennenberg/Week8/shootings.csv") #reading in the dataset from githbub


## Define objects with geo-coordinate system to plot specific information
race = st_as_sf(data.frame(x = -75.3677, y = 39.9168),
                coords = c("x", "y"),
                crs = 4326)
gender = st_as_sf(data.frame(x = -75.3477, y = 39.9168),
                coords = c("x", "y"),
                crs = 4326)
fatal = st_as_sf(data.frame(x = -75.3877, y = 39.9168),
                coords = c("x", "y"),
                crs = 4326)

shootings <- shootings2[complete.cases(shootings2),]

```

# Philadelphia Shootings: Interactive Map

Below is the interactive map that aggregates/collapses information over the entirety of the city of Philadelphia. Circles are shown as red if the shooting was nonfatal, and blue if the shooting was fatal. 

```{r, include=FALSE}

table<-table(shootings$sex)
label<-paste(names(table),"\n", table,sep="")
pie(table, labels=label, main="Pie Chart of Shootings by Gender", col=c("green","purple"))

table2<-table(shootings$race)
label2<-paste(names(table2))
pie(table2, labels=label2, main="Pie Chart of Shootings by Race", col=c("red","yellow","pink","blue"))

table3<-table(shootings$fatal)
label3<-paste(names(table3))
pie(table3, labels=label3, main="Pie Chart of Fatalities", col=c("orange","red"))
legend("bottomleft",c("Non-Fatal","Fatal"), fill=c("orange","red"))

```

```{r}
img1<-"https://isarenn.github.io/irennenberg/Week8/Gender.jpeg"
img2<-"https://isarenn.github.io/irennenberg/Week8/Race.jpeg"
img3<-"https://isarenn.github.io/irennenberg/Week8/Fatal.jpeg"

pal <- colorFactor(c("red", "blue"), domain = c("0", "1"))

Map1<-leaflet(shootings) %>%
  setView(lng=-75.15092, lat=40.00995, zoom = 11) %>%
  addProviderTiles(providers$CartoDB.Positron, group="Positron") %>%
  addProviderTiles(providers$CartoDB.PositronNoLabels, group="PositronLabels") %>%  
  addProviderTiles(providers$Esri.NatGeoWorldMap, group="Esri") %>%
  addMiniMap() %>%
  ## neighborhood boundary
  addPolygons(data = phillyNeighbor,
              color = 'lightpink',
              weight = 2)  %>%
  ## plot information on the map
  addCircleMarkers(data = shootings,
                   radius = ~ifelse(fatal == "1", 5, 3),
                   color = ~pal(fatal),
                   stroke = FALSE, 
                   fillOpacity = 0.5,
                   popup = ~popupTable(shootings),
                   clusterOptions = markerClusterOptions(maxClusterRadius = 40)) %>%
  addLayersControl(baseGroups = c('Positron', 'PositronLabel', 'Esri'),
                   overlayGroups = c("Shootings Data"),
                   options = layersControlOptions(collapsed = TRUE)) %>%
  addCircleMarkers(data = gender, 
                   color = "blue",
                   weight = 2,
                   label = "Gender",
                   stroke = FALSE, 
                   fillOpacity = 0.95,
                   group = "gender") %>%
  addPopupImages(img1, 
                  width = 300,
                  height = 300,
                  tooltip = FALSE,
                  group = "gender")  %>%
  addCircleMarkers(data = race, 
                   color = "purple",
                   weight = 2,
                   label = "Race",
                   stroke = FALSE, 
                   fillOpacity = 0.95,
                   group = "race") %>%
  addPopupImages(img2, 
                  width = 300,
                  height = 300,
                  tooltip = FALSE,
                  group = "race") %>%
  addCircleMarkers(data = fatal, 
                   color = "lightblue",
                   weight = 2,
                   label = "Fatality",
                   stroke = FALSE, 
                   fillOpacity = 0.95,
                   group = "fatal") %>%
  addPopupImages(img3, 
                  width = 300,
                  height = 300,
                  tooltip = FALSE,
                  group = "fatal")  

title<-tags$div(HTML('<font color = "purple" size =4><b>Philadelphia Shootings By Borough</b></font>'))


Map2<-Map1 %>%
  addControl(title, position="topleft")

Map2


```
# Conclusions

From the pop-ups, we can see that the majority of the shootings involved men, and the most prevalent race was black. We can also see that the shootings were primarily non fatal. In addition, we see that the shootings are clustered in the majority of the inner portions of the city. 

Thank you!
