diff options
-rw-r--r-- | app/components/graph/graph.tsx | 27 | ||||
-rw-r--r-- | app/components/tweaks/tweaks.tsx | 12 | ||||
-rw-r--r-- | app/screens/graph/graph-screen.tsx | 2 |
3 files changed, 41 insertions, 0 deletions
diff --git a/app/components/graph/graph.tsx b/app/components/graph/graph.tsx index 00a4910..bf5aff7 100644 --- a/app/components/graph/graph.tsx +++ b/app/components/graph/graph.tsx @@ -198,6 +198,33 @@ export const Graph = observer(function Graph(props: GraphProps): JSX.Element { linkOpacity={physics.linkOpacity} nodeRelSize={physics.nodeRel} linkDirectionalParticleWidth={physics.particleWidth} + nodeCanvasObject={(node, ctx, globalScale) => { + if(physics.labels){ + if(globalScale > physics.labelScale ) { + const label = node.title.substring(0, Math.min(node.title.length, 30)); + const fontSize = 12/globalScale; + ctx.font = `${fontSize}px Sans-Serif`; + const textWidth = ctx.measureText(label).width; + const bckgDimensions = [textWidth, fontSize].map(n => n + fontSize * 0.2); // some padding + + ctx.fillStyle = 'rgba(20, 20, 20, 0.8)'; + ctx.fillRect(node.x - bckgDimensions[0] / 2, node.y - bckgDimensions[1] / 2, ...bckgDimensions); + + ctx.textAlign = 'center'; + ctx.textBaseline = 'middle'; + ctx.fillStyle = "#ffffff"; //node.color; + ctx.fillText(label, node.x, node.y); + + node.__bckgDimensions = bckgDimensions; // to re-use in nodePointerAreaPaint + } + } + }} + nodePointerAreaPaint={(node, color, ctx) => { + ctx.fillStyle = color; + const bckgDimensions = node.__bckgDimensions; + bckgDimensions && ctx.fillRect(node.x - bckgDimensions[0] / 2, node.y - bckgDimensions[1] / 2, ...bckgDimensions); + }} + nodeCanvasObjectMode={()=>'after'} /> ) : ( <ForceGraph3D diff --git a/app/components/tweaks/tweaks.tsx b/app/components/tweaks/tweaks.tsx index 2a2e3d3..e235ad4 100644 --- a/app/components/tweaks/tweaks.tsx +++ b/app/components/tweaks/tweaks.tsx @@ -109,6 +109,18 @@ export const Tweaks = observer(function Tweaks(props: TweaksProps): JSX.Element onValueChange={(value) => { setPhysics({ ...physics, particleWidth: value }) }} value={physics.particleWidth} step={.1} /> + <Text preset="fieldLabel" text="Labels" /> + <Switch style={{ width: "5", height: 20, marginVertical: 10 }} + value={physics.labels} + onValueChange={() => { setPhysics({ ...physics, labels: !physics.labels }) }} + /> + <Text preset="fieldLabel" text={"Scale when labels become visible: " + physics.labelScale} /> + <Slider style={{ height: 40, width: "90%" }} + minimumValue={0.1} + maximumValue={5} + onValueChange={(value) => { setPhysics({ ...physics, labelScale: value }) }} + value={physics.labelScale} + step={.1} /> </View>, }, { diff --git a/app/screens/graph/graph-screen.tsx b/app/screens/graph/graph-screen.tsx index 1c91721..6fa7539 100644 --- a/app/screens/graph/graph-screen.tsx +++ b/app/screens/graph/graph-screen.tsx @@ -46,6 +46,8 @@ export const GraphScreen = observer(function GraphScreen() { linkWidth: 1, particleWidth: 1, nodeRel: 1, + labels: true, + labelScale: 1, } const getData = async () => { |