cytoscape.js 让标签与线错开
按照官方说明,在 stylesheet 中直接使用
1 | edge{ |
可以让连边的 label 正常显示:
data:image/s3,"s3://crabby-images/31fdd/31fdd64eda5e1de477f4891d01594f5d8d614f0e" alt="-w806"
但是,文字覆盖在连边上效果很不好,因此有时候会使用
outline
等方式,让文本更加突出。而根据需求,现在需要让
label 文本和连边错开(即文本在边的上边而不是重合),使用官方提供的
margin 等接口,都会在连边不是水平的时候导致文本的错位:
data:image/s3,"s3://crabby-images/9ecc1/9ecc123bf7ebee9ec9c6141a652b61411a93e174" alt="-w575"
data:image/s3,"s3://crabby-images/fe6a3/fe6a38ad757532a990b3ec83cfe271e5ec588555" alt="-w220"
上面两个图片是
1 | edge{ |
的效果。
解决方案
1 | graph.cy.style().selector('edge').style({'label': label => label.data().name + "\n\n\u200b"}).update() |
直接让一行标签变成三行标签,这样就刚好和连边错开了。其中
\u200b
是空白的字符,在图中不会显示,拿来做占位符恰好合适。效果如下:
data:image/s3,"s3://crabby-images/682d0/682d07fe8a54272524741f334a9ea92c16d3ae53" alt="-w310"