sf function

sf methods for sfnetworks

sf methods for sfnetworks

sf methods for sfnetwork objects.

## S3 method for class 'sfnetwork' st_as_sf(x, active = NULL, ...) ## S3 method for class 'sfnetwork' st_as_s2(x, active = NULL, ...) ## S3 method for class 'sfnetwork' st_geometry(obj, active = NULL, ...) ## S3 replacement method for class 'sfnetwork' st_geometry(x) <- value ## S3 method for class 'sfnetwork' st_drop_geometry(x, ...) ## S3 method for class 'sfnetwork' st_bbox(obj, active = NULL, ...) ## S3 method for class 'sfnetwork' st_coordinates(x, active = NULL, ...) ## S3 method for class 'sfnetwork' st_is(x, ...) ## S3 method for class 'sfnetwork' st_is_valid(x, ...) ## S3 method for class 'sfnetwork' st_crs(x, ...) ## S3 replacement method for class 'sfnetwork' st_crs(x) <- value ## S3 method for class 'sfnetwork' st_precision(x) ## S3 method for class 'sfnetwork' st_set_precision(x, precision) ## S3 method for class 'sfnetwork' st_shift_longitude(x, ...) ## S3 method for class 'sfnetwork' st_transform(x, ...) ## S3 method for class 'sfnetwork' st_wrap_dateline(x, ...) ## S3 method for class 'sfnetwork' st_normalize(x, ...) ## S3 method for class 'sfnetwork' st_zm(x, ...) ## S3 method for class 'sfnetwork' st_m_range(obj, active = NULL, ...) ## S3 method for class 'sfnetwork' st_z_range(obj, active = NULL, ...) ## S3 method for class 'sfnetwork' st_agr(x, active = NULL, ...) ## S3 replacement method for class 'sfnetwork' st_agr(x) <- value ## S3 method for class 'sfnetwork' st_reverse(x, ...) ## S3 method for class 'sfnetwork' st_simplify(x, ...) ## S3 method for class 'sfnetwork' st_join(x, y, ...) ## S3 method for class 'morphed_sfnetwork' st_join(x, y, ...) ## S3 method for class 'sfnetwork' st_filter(x, y, ...) ## S3 method for class 'morphed_sfnetwork' st_filter(x, y, ...) ## S3 method for class 'sfnetwork' st_crop(x, y, ...) ## S3 method for class 'morphed_sfnetwork' st_crop(x, y, ...) ## S3 method for class 'sfnetwork' st_difference(x, y, ...) ## S3 method for class 'morphed_sfnetwork' st_difference(x, y, ...) ## S3 method for class 'sfnetwork' st_intersection(x, y, ...) ## S3 method for class 'morphed_sfnetwork' st_intersection(x, y, ...) ## S3 method for class 'sfnetwork' st_intersects(x, y, ...) ## S3 method for class 'sfnetwork' st_sample(x, ...) ## S3 method for class 'sfnetwork' st_nearest_points(x, y, ...) ## S3 method for class 'sfnetwork' st_area(x, ...)

Arguments

  • x: An object of class sfnetwork.
  • active: Which network element (i.e. nodes or edges) to activate before extracting. If NULL, it will be set to the current active element of the given network. Defaults to NULL.
  • ...: Arguments passed on the corresponding sf function.
  • obj: An object of class sfnetwork.
  • value: The value to be assigned. See the documentation of the corresponding sf function for details.
  • precision: The precision to be assigned. See st_precision for details.
  • y: An object of class sf, or directly convertible to it using st_as_sf. In some cases, it can also be an object of sfg or bbox. Always look at the documentation of the corresponding sf function for details.

Returns

The sfnetwork method for st_as_sf returns the active element of the network as object of class sf. The sfnetwork and morphed_sfnetwork methods for st_join, st_filter, st_intersection, st_difference, st_crop and the setter functions return an object of class sfnetwork

and morphed_sfnetwork respectively. All other methods return the same type of objects as their corresponding sf function. See the sf documentation for details.

Details

See the sf documentation.

Examples

library(sf, quietly = TRUE) net = as_sfnetwork(roxel) # Extract the active network element. st_as_sf(net) # Extract any network element. st_as_sf(net, "edges") # Get geometry of the active network element. st_geometry(net) # Get geometry of any network element. st_geometry(net, "edges") # Get bbox of the active network element. st_bbox(net) # Get CRS of the network. st_crs(net) # Get agr factor of the active network element. st_agr(net) # Get agr factor of any network element. st_agr(net, "edges") # Spatial join applied to the active network element. net = st_transform(net, 3035) codes = st_as_sf(st_make_grid(net, n = c(2, 2))) codes$post_code = as.character(seq(1000, 1000 + nrow(codes) * 10 - 10, 10)) joined = st_join(net, codes, join = st_intersects) joined oldpar = par(no.readonly = TRUE) par(mar = c(1,1,1,1), mfrow = c(1,2)) plot(net, col = "grey") plot(codes, col = NA, border = "red", lty = 4, lwd = 4, add = TRUE) text(st_coordinates(st_centroid(st_geometry(codes))), codes$post_code) plot(st_geometry(joined, "edges")) plot(st_as_sf(joined, "nodes"), pch = 20, add = TRUE) par(oldpar) # Spatial filter applied to the active network element. p1 = st_point(c(4151358, 3208045)) p2 = st_point(c(4151340, 3207520)) p3 = st_point(c(4151756, 3207506)) p4 = st_point(c(4151774, 3208031)) poly = st_multipoint(c(p1, p2, p3, p4)) %>% st_cast('POLYGON') %>% st_sfc(crs = 3035) %>% st_as_sf() filtered = st_filter(net, poly, .pred = st_intersects) oldpar = par(no.readonly = TRUE) par(mar = c(1,1,1,1), mfrow = c(1,2)) plot(net, col = "grey") plot(poly, border = "red", lty = 4, lwd = 4, add = TRUE) plot(filtered) par(oldpar)