class: title-slide, center, middle # GIS in Archaeology ## 02 - Working with QGIS ### Martin Hinz #### Institut für Archäologische Wissenschaften, Universität Bern 02/10/24 .footnote[ .right[ .tiny[ based on [Datapolitan-Training/qgis-training](https://github.com/Datapolitan-Training/qgis-training). You can download a [pdf of this presentation](https://berncodalab.github.io/gia/lectures/02/gis_in_archaeology_02.pdf). ] ] ] --- <!-- opening shapefile --> #Let's Get Started 1. [Click this link](https://github.com/BernCoDALab/gia/raw/main/lectures/01/data/points.zip) and download the file to your desktop 2. Unzip the file 3. [Click this link](https://github.com/BernCoDALab/gia/raw/main/lectures/01/data/background.tiff) and download the other file also to your desktop 3. Open QGIS data:image/s3,"s3://crabby-images/6965a/6965a5e8e7db6ddf1b9c7504bd49bc37e3187316" alt="" --- ## Layers data:image/s3,"s3://crabby-images/1f80f/1f80fcc3285a1e8a944720cd6e35b6558a3529b8" alt="img-full" #### Image Source: http://www.geocontrolling.com/co-je-gis.htm --- # Layer Ordering -- + Layers on top are drawn on top -- + Just drag and drop within the Layers Panel to change order -- + Try it now --- ## Shapefiles -- + Basic file for storing map elements -- + Stores spatial data, like points, lines, and polygons -- + Multiple files comprise a "shapefile" -- data:image/s3,"s3://crabby-images/56213/562131118f0692180d69c276977f38ba2d311026" alt="img-center-80" --- ## Shapefiles data:image/s3,"s3://crabby-images/56213/562131118f0692180d69c276977f38ba2d311026" alt="img-center-80" -- + .shp—The main file that stores the feature geometry -- + .dbf—The dBASE table that stores the attribute information of features --- ## Shapefiles data:image/s3,"s3://crabby-images/56213/562131118f0692180d69c276977f38ba2d311026" alt="img-center-80" + .prj—The file that stores the coordinate system information -- + .shx—The index file that stores the index of the feature geometry --- ## You might also see -- + .cpg—Identifies the character set to be used -- + .sbn and .sbx—The files that store the spatial index of the features --- ## Shapefiles + Have a few limitations -- + One geometry type (Point, Line, Polygon) per shapefile -- + So sometimes you end up with this: data:image/s3,"s3://crabby-images/3e827/3e82761aa94307b5068b0f17f812434a06536436" alt="img" --- ## Overview of GeoPackage .pull-left[ * What is GeoPackage? * A data format for geographic information systems (GIS). * Platform-independent, open, and standards-based. * Uses an SQLite database to store both raster and vector data. * Key Features: * Single file for easy data sharing and use. * Efficient, especially for mobile and offline environments. * Supports extensions for flexibility (OGC-approved and custom extensions). * Why Use GeoPackage? * Lightweight and portable. * Facilitates easy data management and spatial queries. ] .pull-right[ data:image/s3,"s3://crabby-images/3186e/3186ea0be72fb603e1b028cb0c6deb52552856b3" alt="img" ] --- ## GeoPackage vs. Shapefiles 1. **File Structure:** - **GeoPackage:** Single file (SQLite-based). - **Shapefile:** Requires multiple files (.shp, .shx, .dbf, etc.). 2. **Data Handling:** - **GeoPackage:** Stores both vector and raster data (multiple geometry type per file possible) - **Shapefile:** Vector data only. 3. **Efficiency:** - **GeoPackage:** Compact, better suited for mobile/offline use. - **Shapefile:** Larger, more fragmented. 4. **Attributes:** - **GeoPackage:** Supports larger field names and Unicode. - **Shapefile:** Limited field length and ASCII-only. --- ## Attribute Table (Right click on layer) data:image/s3,"s3://crabby-images/a986c/a986c2abd641ee7b611ff36714af9f66866c4544" alt=":width 90%" --- ## Attribute Table .pull-left[ ### Table View data:image/s3,"s3://crabby-images/03b17/03b17e4f6f9a7d0c2b5a1b72f1c3efecf39a9a30" alt="img" ] .pull-right[ ### Form View data:image/s3,"s3://crabby-images/3e338/3e3382e87091ffe84f9e31ca26db2d1196afc946" alt="img" ] --- ## Shapefiles and Attribute Tables -- + Column names can only be letters, numbers, and underscores "_" -- + Column names can only be ten characters long -- data:image/s3,"s3://crabby-images/03b17/03b17e4f6f9a7d0c2b5a1b72f1c3efecf39a9a30" alt=":width 70%" --- class:center,middle # Let's add another layer --- ## Going out in Bern + [Download the data](https://github.com/BernCoDALab/gia/raw/main/lectures/02/data/going_out_in_bern.zip) to your desktop + Unzip the file + Open in QGIS data:image/s3,"s3://crabby-images/9f536/9f536a30c6390644df37d28a199d52ea27179140" alt=":width 70%" --- ## Going out in Bern data:image/s3,"s3://crabby-images/f35d4/f35d486566830a76bc485ed5ae9001e2951d9fa1" alt=":width 90%" --- # Filter and Query + We can filter the points based on the values in the attribute table --- # Filter and Query + Right-click on the layer and select "Filter" to open the Query Builder data:image/s3,"s3://crabby-images/8157f/8157f5619dfb7f878466481016189a81f3ebb05b" alt=":width 75%" --- # Filter and Query data:image/s3,"s3://crabby-images/ed803/ed8032e573612621d41df182ee549cfb144797e8" alt=":width 75%" --- # Filter and Query data:image/s3,"s3://crabby-images/5cac8/5cac8427a9f910145135165d1a118031afe1a80c" alt=":width 50%" -- data:image/s3,"s3://crabby-images/3c436/3c436a4a544c953bc3fe8939c34925a620df89b0" alt=":width 50%" --- # Filter and Query data:image/s3,"s3://crabby-images/04ac8/04ac85c1eb168c02436f0f96e4b6676575315741" alt=":width 75%" --- # Filter and Query data:image/s3,"s3://crabby-images/8a997/8a9976598764b9ce49093a23de2c2a6226e4ec81" alt=":width 75%" --- class:center,middle # We can also filter by multiple conditions --- # Filter and Query - Multiple Conditions data:image/s3,"s3://crabby-images/f3611/f36115649b2f891a4bdf9b712b11336946693f5a" alt=":width 50%" -- data:image/s3,"s3://crabby-images/c2137/c2137debb40eebd40ab38aafdd0718450a5d46f2" alt=":width 50%" --- # Filter and Query - Multiple Conditions data:image/s3,"s3://crabby-images/8a459/8a459a19509421068e9b7f09d9828864334c9758" alt=":width 75%" --- # Zoom to Layer data:image/s3,"s3://crabby-images/19dae/19dae2d64c44b3da6a7ca0c7bb0357b898636075" alt=":width 50%" -- data:image/s3,"s3://crabby-images/305d1/305d1e0eb0b08805607a8412f9bb0a8c077e1fde" alt=":width 50%" --- # Zoom Selection -- + Select the zoom on the toolbar data:image/s3,"s3://crabby-images/14f53/14f5380ab03389c4e84538855eefdb597beda2e0" alt="img-right-30" -- + Draw a box around the area you want to zoom into -- + Click the icon to return to the previous map extent data:image/s3,"s3://crabby-images/64974/649747cd220f727e018afc1008b20e21a2c2bc1b" alt="img-right-30" --- # Pan Map + Select the hand tool to pan around the map data:image/s3,"s3://crabby-images/8d830/8d830acca7f648a66987879bef2608907c57b704" alt="img-center-30" --- # Exporting Data data:image/s3,"s3://crabby-images/1cb77/1cb778dcfab95ddfb7d2076a42de0080d836e588" alt=":width 50%" -- data:image/s3,"s3://crabby-images/e473f/e473f60a0378fb67e6898de7d26fb2997c3f96b5" alt=":width 50%" --- # Your Turn + Filter according to your own criteria + Try and find something interesting + Change the style of the point, either to a different shape, color, or icon + Export your selection as a new shapefile --- ## CSV-Files + General (textbased) spreadsheat format -- + simple and robust -- + human readable (kind of) -- data:image/s3,"s3://crabby-images/67766/67766c570a3be1da1a3fb4b9a5c9c63c55d1c3bd" alt=":width 100%" --- ## CSV-Files + Perfect for data exchange between Spreadsheet (Excel) and GIS data:image/s3,"s3://crabby-images/67766/67766c570a3be1da1a3fb4b9a5c9c63c55d1c3bd" alt=":width 50%"data:image/s3,"s3://crabby-images/9d611/9d61118f2ecbe8bb696af9adf121ae9f2672be6e" alt=":width 50%" --- ## CSV Import - Bicycle Rental + [Download the data](https://github.com/BernCoDALab/gia/raw/main/lectures/02/data/bicycle_rent.csv) to your desktop data:image/s3,"s3://crabby-images/67766/67766c570a3be1da1a3fb4b9a5c9c63c55d1c3bd" alt=":width 50%"data:image/s3,"s3://crabby-images/9d611/9d61118f2ecbe8bb696af9adf121ae9f2672be6e" alt=":width 50%" --- ## CSV Import - Bicycle Rental Load Text Layer data:image/s3,"s3://crabby-images/8e2f3/8e2f3d8d3e736aa6d5a60b983b1ef2f6f5dd7feb" alt=":width 75%" --- ## CSV Import - Bicycle Rental Set coordinate columns data:image/s3,"s3://crabby-images/8660a/8660aa7aea7f6b83d26149613cdfc46e230ccb06" alt=":width 50%" --- ## CSV Import - Bicycle Rental Set coordinate columns and Coordinate Reference System <- We will explain this in a bit! You can also access more detailed Coordinate Reference settings. data:image/s3,"s3://crabby-images/38fd4/38fd40c128f688ca75d70953cdc5f6f39b0a2d16" alt=":width 50%"data:image/s3,"s3://crabby-images/85ad0/85ad0b9efd3a7c79787c013c07bd553ea3b6b29d" alt=":width 50%" --- class:center,middle # So what is a Coordinate Reference System? --- # Projections -- + No one's favorite part of GIS -- + But a necessary part of it nonetheless -- + Convert points on the 3-dimensional Earth (**latitude** and **longitude**) to x and y coordinates on a 2-dimensional map -- data:image/s3,"s3://crabby-images/6290f/6290f08bb5ced360b9a6897a6a320d14c155c372" alt="img-center-85" [Digital Coast Geozone](https://geozoneblog.wordpress.com/2012/05/22/happy-birthday-mercator/) --- # Projections + Every projection distorts some part of your map data:image/s3,"s3://crabby-images/0b6ad/0b6adab472ffb3bed45fb1f1527b0fb4b584ca68" alt=":width 40%" [FlowingData](http://flowingdata.com/2014/01/13/map-projections-illustrated-with-a-face/) --- # Mercator Projections -- + A common map projection -- + Makes geometries near poles look bigger than geometries near the equator -- data:image/s3,"s3://crabby-images/c6e2b/c6e2b6643ed76e6ef4f34065a88c9b809166f89e" alt=":width 40%" --- # Projections Matter -- + These circles are all the same size on the globe: data:image/s3,"s3://crabby-images/3f30d/3f30d11b2b2cd629bf78fce48aaef7c9360c2058" alt=":width 45%" [Progonos](http://www.progonos.com/furuti/MapProj/Normal/CartProp/Distort/distort.html) + Conformal map projection (Winkeltreu) --- # Projections Matter + As are these: data:image/s3,"s3://crabby-images/bc8f1/bc8f1281008d278c40e4cd1f91f3010a67090d16" alt="img-center-60" [Progonos](http://www.progonos.com/furuti/MapProj/Normal/CartProp/Distort/distort.html) + Equal-area projection (Flächentreu) --- # Projections Matter + And these: data:image/s3,"s3://crabby-images/a9d5b/a9d5bc821851b812cc4086406550b1cd9720724e" alt=":width 45%" [Progonos](http://www.progonos.com/furuti/MapProj/Normal/CartProp/Distort/distort.html) --- # Projections Matter data:image/s3,"s3://crabby-images/614d8/614d8a5f8b60c53b6d38af087d2f2056b239c7b8" alt=":width 80%" --- # Projections + For the most part we will work in **WGS 84** (latitude and longitude) -- + In Switzerland, we use a more accurate projection **CHTRS95: Swiss Terrestrial Reference System 1995** that is identical with the european system **ETRS89**. + You might also find 'Schweizer Landeskoordinaten' (CH1903) or Landesvermessung 1903 (LV03) data:image/s3,"s3://crabby-images/5ee65/5ee65af60fe8212cf801aa8bae80beb94dffa19f" alt=":width 40%" ###### Source: https://www.swisstopo.admin.ch/de/wissen-fakten/geodaesie-vermessung/bezugsrahmen/lokal/lv95.html --- # Projections + Identified by unique IDs (**EPSG**) that make it easier to talk about them + EPSG: European Petroleum Survey Group Geodesy (it was introduced, because Oil companies were annoyed by the incredible number of different systems) -- + WGS 84 is referred to as **EPSG:4326** -- + Google Maps and other online sources often uses WGS 84 / Pseudo-Mercator (**EPSG:3857**) -- + CHTRS95 is referred to as **EPSG:2056** -- ## Remember these three and you should be set --- class:center,middle # Back to Adding CSV Data --- # Adding CSV Data data:image/s3,"s3://crabby-images/cc3ae/cc3ae42dcc622fd311dbf65d7f7ede53316257a5" alt=":width 40%" --- ## CSV Import - Bicycle Rental Bicycles added. data:image/s3,"s3://crabby-images/a1925/a192561b88a452093746b69aae30f333ade07303" alt=":width 75%" --- # What We've Covered -- + Adding, styling, and labeling data in QGIS -- + Projections -- + Querying features --- # Homework + Add the files you can download from the homework page to QGIS (note: the projection epsg is in the filename) + background_4326.tif + cities_2056.csv + lakes_3857.gpkg + Style as you like + Send me a screenshot --- class: inverse, middle, center # Any questions? data:image/s3,"s3://crabby-images/6b3a9/6b3a9a64198469d17712198ff09e339cf45c1357" alt=":width 20%" .caption[Source: https://www.instagram.com/sadtopographies] .footnote[ .right[ .tiny[ You might find the course material (including the presentations) at https://github.com/BernCoDALab/gia You can see the rendered presentations at https://berncodalab.github.io/gia You can contact me at <a href="mailto:martin.hinz@unibe.ch">martin.hinz@unibe.ch</a> ] ] ]