Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Color problems in nodes #473

Open
TimothyEbert opened this issue Jul 31, 2024 · 3 comments
Open

Color problems in nodes #473

TimothyEbert opened this issue Jul 31, 2024 · 3 comments

Comments

@TimothyEbert
Copy link

I am using RStudio running on a PC (DELL Latitude 7440) using R 4.4.1 and RStudio version 2024.4.2.764.
I am making network plots with 6 nodes.
I assign custom colors to the nodes and edges.

The problem is that some colors appear to cause problems where some edges and nodes to not appear with the right color. I check the edges data frame, and the colors are correct but an edge with one color in the data frame will print as a different color.
This graph is good:
image
If I change to "brown4" then I get this:
image

Is there a pallet that does not have problems, or what is causing this issue?

@TimothyEbert
Copy link
Author

The following is a minimally reproducible example where I have removed all of the code that converts the raw data into node and edges. I have also left out code that adjusts the physics.

library(visNetwork)

Build nodes

nodes <- data.frame(
id=c("C", "G", "NP", "D", "E1", "E2"),
label=c("C", "G", "NP", "D", "E1", "E2"),
size = c(45.095856, 37.859089, 116.437705,
1.546333, 1.373999, 23.07729),
color.background = c("cyan", "blue", "brown4",
"lightgreen", "lightgreen", "lightgreen")
)

Build edges

edges <- data.frame(
to = c('C', 'C', 'C', 'D', 'D', 'E1', 'E1',
'E2', 'E2', 'G', 'G', 'NP'),
from = c('D', 'G', 'NP', 'C', 'E1',
'C', 'E2', 'C', 'E1', 'C', 'NP', 'C'),
width = c(5.135724, 5.629823, 13.597379, 12.25, 12.4,
15.97265, 6.712251, 10, 13.333333, 19.62963, 6.666667, 20),
arrows = "to",
font_multi = "html",
color = c('lightgreen', 'blue', 'brown4', 'cyan', 'lightgreen', 'cyan',
'lightgreen', 'cyan', 'lightgreen', 'cyan', 'brown4', 'cyan')
)
visNetwork(nodes, edges)

Code where color works

Build nodes

nodes <- data.frame(
id=c("C", "G", "NP", "D", "E1", "E2"),
label=c("C", "G", "NP", "D", "E1", "E2"),
size = c(45.095856, 37.859089, 116.437705,
1.546333, 1.373999, 23.07729),
color.background = c("cyan", "blue", "brown",
"lightgreen", "lightgreen", "lightgreen")
)

Build edges

edges <- data.frame(
to = c('C', 'C', 'C', 'D', 'D', 'E1', 'E1',
'E2', 'E2', 'G', 'G', 'NP'),
from = c('D', 'G', 'NP', 'C', 'E1',
'C', 'E2', 'C', 'E1', 'C', 'NP', 'C'),
width = c(5.135724, 5.629823, 13.597379, 12.25, 12.4,
15.97265, 6.712251, 10, 13.333333, 19.62963, 6.666667, 20),
arrows = "to",
font_multi = "html",
color = c('lightgreen', 'blue', 'brown', 'cyan', 'lightgreen', 'cyan',
'lightgreen', 'cyan', 'lightgreen', 'cyan', 'brown', 'cyan')
)
visNetwork(nodes, edges)

@philibe
Copy link

philibe commented Oct 22, 2024

In simple html brown4 gives /!\Invalid Property Value in F12/debug of a browser.

They works:

  • htmltools::browsable(tags$html( span("salut",style="color: red; font-style: italic;")))
  • <html><head><meta charset="utf-8"></head><body> <span style="color: red; font-style: italic;">salut</span></body></html>

Their color doesn't work:

  • htmltools::browsable(tags$html( span("salut",style="color: brown4; font-style: italic;")))
  • <html><head><meta charset="utf-8"></head><body> <span style="color: brown4; font-style: italic;">salut</span></body></html>

brown4 doesn't seem exist in in https://www.w3.org/wiki/CSS/Properties/color/keywords

@ampitera
Copy link

ampitera commented Dec 12, 2024

@TimothyEbert Just in case you're still trying to use "brown4", you just need to use rgb/rgba for colors that don't have a CSS color keyword. I've found that using hex values instead of color names is a good habit to get into if you're working with packages that rely on CSS (e.g. {shiny}, {plotly}, etc...).

I've demonstrated three different options in my suggested fix below.

If this works for you, I reckon this issue should be marked as closed since it isn't particularly package-specific.

  id=c("C", "G", "NP", "D", "E1", "E2"),
  label=c("C", "G", "NP", "D", "E1", "E2"),
  size = c(45.095856, 37.859089, 116.437705,
           1.546333, 1.373999, 23.07729),
  color.background = c("cyan", "blue", "rgb(139, 35, 35)", # rgb for "brown4"
                       "lightgreen", "lightgreen", "lightgreen")
)

edges <- data.frame(
  to = c('C', 'C', 'C', 'D', 'D', 'E1', 'E1',
         'E2', 'E2', 'G', 'G', 'NP'),
  from = c('D', 'G', 'NP', 'C', 'E1',
           'C', 'E2', 'C', 'E1', 'C', 'NP', 'C'),
  width = c(5.135724, 5.629823, 13.597379, 12.25, 12.4,
            15.97265, 6.712251, 10, 13.333333, 19.62963, 6.666667, 20),
  arrows = "to",
  font_multi = "html",
  color = c('lightgreen', 'blue',  "#8B2323", # hex for "brown4"
            'cyan', 'lightgreen', 'cyan','lightgreen', 'cyan',
            'lightgreen', 'cyan',  "rgba(139, 35, 35, 1)", # rgba for "brown4"
            'cyan')
)
visNetwork::visNetwork(nodes, edges)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants