Nothing
test_that("segments don't have fill", {
x <- xmlSVG({
plot.new()
segments(0.5, 0.5, 1, 1)
})
style <- xml2::xml_text(xml2::xml_find_first(x, "//d1:style"))
expect_match(style, "fill: none;")
expect_equal(style_attr(xml2::xml_find_first(x, ".//d1:line"), "fill"), NA_character_)
})
test_that("lines don't have fill", {
x <- xmlSVG({
plot.new()
lines(c(0.5, 1, 0.5), c(0.5, 1, 1))
})
expect_equal(style_attr(xml2::xml_find_first(x, ".//d1:polyline"), "fill"), NA_character_)
})
test_that("polygons do have fill", {
x <- xmlSVG({
plot.new()
polygon(c(0.5, 1, 0.5), c(0.5, 1, 1), col = "red", border = "blue")
})
polygon <- xml2::xml_find_first(x, ".//d1:polygon")
expect_equal(style_attr(polygon, "fill"), rgb(1, 0, 0))
expect_equal(style_attr(polygon, "stroke"), rgb(0, 0, 1))
})
test_that("polygons without border", {
x <- xmlSVG({
plot.new()
polygon(c(0.5, 1, 0.5), c(0.5, 1, 1), col = "red", border = NA)
})
polygon <- xml2::xml_find_first(x, ".//d1:polygon")
expect_equal(style_attr(polygon, "fill"), rgb(1, 0, 0))
expect_equal(style_attr(polygon, "stroke"), "none")
})
test_that("blank lines are omitted", {
x <- xmlSVG(mini_plot(1:3, lty = "blank", type = "l"))
expect_equal(length(xml2::xml_find_all(x, "//d1:polygon")), 0)
})
test_that("lines lty becomes stroke-dasharray", {
expect_equal(dash_array(lty = 1), NA_integer_)
expect_equal(dash_array(lty = 2), c(4, 4))
expect_equal(dash_array(lty = 3), c(1, 3))
expect_equal(dash_array(lty = 4), c(1, 3, 4, 3))
expect_equal(dash_array(lty = 5), c(7, 3))
expect_equal(dash_array(lty = 6), c(2, 2, 6, 2))
expect_equal(dash_array(lty = "1F"), c(1, 15))
expect_equal(dash_array(lty = "1234"), c(1, 2, 3, 4))
})
test_that("stroke-dasharray scales with lwd > 1", {
expect_equal(dash_array(lty = 2, lwd = 1), c(4, 4))
expect_equal(dash_array(lty = 2, lwd = 1/2), c(4, 4))
expect_equal(dash_array(lty = 2, lwd = 1.1), c(4.4, 4.4))
expect_equal(dash_array(lty = 2, lwd = 2), c(8, 8))
})
test_that("line end shapes", {
x1 <- xmlSVG({
plot.new()
lines(c(0.3, 0.7), c(0.5, 0.5), lwd = 15, lend = "round")
})
x2 <- xmlSVG({
plot.new()
lines(c(0.3, 0.7), c(0.5, 0.5), lwd = 15, lend = "butt")
})
x3 <- xmlSVG({
plot.new()
lines(c(0.3, 0.7), c(0.5, 0.5), lwd = 15, lend = "square")
})
style <- xml2::xml_text(xml2::xml_find_first(x1, "//d1:style"))
expect_match(style, "stroke-linecap: round;")
expect_equal(style_attr(xml2::xml_find_first(x1, ".//d1:polyline"), "stroke-linecap"), NA_character_)
expect_equal(style_attr(xml2::xml_find_first(x2, ".//d1:polyline"), "stroke-linecap"), "butt")
expect_equal(style_attr(xml2::xml_find_first(x3, ".//d1:polyline"), "stroke-linecap"), "square")
})
test_that("line join shapes", {
x1 <- xmlSVG({
plot.new()
lines(c(0.3, 0.5, 0.7), c(0.1, 0.9, 0.1), lwd = 15, ljoin = "round")
})
x2 <- xmlSVG({
plot.new()
lines(c(0.3, 0.5, 0.7), c(0.1, 0.9, 0.1), lwd = 15, ljoin = "mitre", lmitre = 10)
})
x3 <- xmlSVG({
plot.new()
lines(c(0.3, 0.5, 0.7), c(0.1, 0.9, 0.1), lwd = 15, ljoin = "mitre", lmitre = 4)
})
x4 <- xmlSVG({
plot.new()
lines(c(0.3, 0.5, 0.7), c(0.1, 0.9, 0.1), lwd = 15, ljoin = "bevel")
})
style <- xml2::xml_text(xml2::xml_find_first(x1, "//d1:style"))
expect_match(style, "stroke-linejoin: round;")
expect_match(style, "stroke-miterlimit: 10.00;")
expect_equal(style_attr(xml2::xml_find_all(x1, ".//d1:polyline"), "stroke-linejoin"), NA_character_)
expect_equal(style_attr(xml2::xml_find_all(x2, ".//d1:polyline"), "stroke-linejoin"), "miter")
expect_equal(style_attr(xml2::xml_find_all(x2, ".//d1:polyline"), "stroke-miterlimit"), NA_character_)
expect_equal(style_attr(xml2::xml_find_all(x3, ".//d1:polyline"), "stroke-linejoin"), "miter")
expect_equal(style_attr(xml2::xml_find_all(x3, ".//d1:polyline"), "stroke-miterlimit"), "4.00")
expect_equal(style_attr(xml2::xml_find_all(x4, ".//d1:polyline"), "stroke-linejoin"), "bevel")
})
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.