diff options
author | Kirill Rogovoy <[email protected]> | 2021-07-22 17:02:14 +0300 |
---|---|---|
committer | Kirill Rogovoy <[email protected]> | 2021-07-22 17:16:20 +0300 |
commit | 666d7e8adccbc384643598ae460c98a42d0b8e28 (patch) | |
tree | e90863650d1c509a65f9e545f4041c107783fd11 /app_expo/components/graph/graph.tsx | |
parent | a9edb982f57cd5ed6676986bcf06555d150a28ab (diff) |
Add scoping and 3D graph
Diffstat (limited to 'app_expo/components/graph/graph.tsx')
-rw-r--r-- | app_expo/components/graph/graph.tsx | 184 |
1 files changed, 5 insertions, 179 deletions
diff --git a/app_expo/components/graph/graph.tsx b/app_expo/components/graph/graph.tsx index 0c959ec..5fc28e4 100644 --- a/app_expo/components/graph/graph.tsx +++ b/app_expo/components/graph/graph.tsx @@ -282,81 +282,13 @@ onLinkHover={handleLinkHover} {!threeDim ? ( <ForceGraph2D ref={fgRef} - //autoPauseRedraw={false} - //graphData={gData} graphData={local ? localGraphData : gData} - //nodeAutoColorBy={physics.colorful ? (node)=>node.index%GROUPS : undefined} - nodeColor={ - !physics.colorful - ? (node) => { - if (highlightNodes.size === 0) { - return 'rgb(100, 100, 100, 1)' - } else { - return highlightNodes.has(node) ? '#a991f1' : 'rgb(50, 50, 50, 0.5)' - } - } - : (node) => { - if (node.neighbors.length === 1 || node.neighbors.length === 2) { - return [ - '#ff665c', - '#e69055', - '#7bc275', - '#4db5bd', - '#FCCE7B', - '#51afef', - '#1f5582', - '#C57BDB', - '#a991f1', - '#5cEfFF', - '#6A8FBF', - ][node.neighbors[0].index % 11] - } else { - return [ - '#ff665c', - '#e69055', - '#7bc275', - '#4db5bd', - '#FCCE7B', - '#51afef', - '#1f5582', - '#C57BDB', - '#a991f1', - '#5cEfFF', - '#6A8FBF', - ][node.index % 11] - } - } - } - //linkAutoColorBy={physics.colorful ? ((d) => gData.nodes[d.sourceIndex].id % GROUPS) : undefined} - linkColor={ - !physics.colorful - ? (link) => { - if (highlightLinks.size === 0) { - return 'rgb(50, 50, 50, 0.8)' - } else { - return highlightLinks.has(link) ? '#a991f1' : 'rgb(50, 50, 50, 0.2)' - } - } - : (link) => - [ - '#ff665c', - '#e69055', - '#7bc275', - '#4db5bd', - '#FCCE7B', - '#51afef', - '#1f5582', - '#C57BDB', - '#a991f1', - '#5cEfFF', - '#6A8FBF', - ][gData.nodes[link.sourceIndex].index % 11] - } + nodeColor={} + linkColor={} linkDirectionalParticles={physics.particles} onNodeClick={selectClick} nodeLabel={(node) => node.title} linkWidth={(link) => - highlightLinks.has(link) ? 3 * physics.linkWidth : physics.linkWidth } linkOpacity={physics.linkOpacity} nodeRelSize={physics.nodeRel} @@ -364,49 +296,7 @@ onLinkHover={handleLinkHover} return highlightNodes.has(node) ? node.neighbors.length + 5 : node.neighbors.length + 3 }} linkDirectionalParticleWidth={physics.particleWidth} - nodeCanvasObject={(node, ctx, globalScale) => { - if (physics.labels) { - if (globalScale > physics.labelScale || highlightNodes.has(node)) { - 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 * 1.1, fontSize].map((n) => n + fontSize * 0.5) // some padding - const fadeFactor = Math.min( - (3 * (globalScale - physics.labelScale)) / physics.labelScale, - 1, - ) - - ctx.fillStyle = - 'rgba(20, 20, 20, ' + - (highlightNodes.size === 0 - ? 0.5 * fadeFactor - : highlightNodes.has(node) - ? 0.5 - : 0.15 * fadeFactor) + - ')' - ctx.fillRect( - node.x - bckgDimensions[0] / 2, - node.y - bckgDimensions[1] / 2, - ...bckgDimensions, - ) - - ctx.textAlign = 'center' - ctx.textBaseline = 'middle' - ctx.fillStyle = - 'rgb(255, 255, 255, ' + - (highlightNodes.size === 0 - ? fadeFactor - : highlightNodes.has(node) - ? 1 - : 0.3 * fadeFactor) + - ')' - ctx.fillText(label, node.x, node.y) - - node.__bckgDimensions = bckgDimensions // to re-use in nodePointerAreaPaint - } - } - }} + nodeCanvasObject={} nodeCanvasObjectMode={() => 'after'} onNodeHover={physics.hover ? handleNodeHover : null} //onLinkHover={physics.hover ? handleLinkHover : null} @@ -420,73 +310,9 @@ onLinkHover={handleLinkHover} <ForceGraph3D ref={fgRef} graphData={!local ? gData : localGraphData} - //graphData={gData} - nodeColor={ - !physics.colorful - ? (node) => { - if (highlightNodes.size === 0) { - return 'rgb(100, 100, 100, 1)' - } else { - return highlightNodes.has(node) ? 'purple' : 'rgb(50, 50, 50, 0.5)' - } - } - : (node) => { - if (node.neighbors.length === 1 || node.neighbors.length === 2) { - return [ - '#ff665c', - '#e69055', - '#7bc275', - '#4db5bd', - '#FCCE7B', - '#51afef', - '#1f5582', - '#C57BDB', - '#a991f1', - '#5cEfFF', - '#6A8FBF', - ][node.neighbors[0].index % 11] - } else { - return [ - '#ff665c', - '#e69055', - '#7bc275', - '#4db5bd', - '#FCCE7B', - '#51afef', - '#1f5582', - '#C57BDB', - '#a991f1', - '#5cEfFF', - '#6A8FBF', - ][node.index % 11] - } - } - } + nodeColor={} //linkAutoColorBy={physics.colorful ? ((d) => gData.nodes[d.sourceIndex].id % GROUPS) : undefined} - linkColor={ - !physics.colorful - ? (link) => { - if (highlightLinks.size === 0) { - return 'rgb(50, 50, 50, 0.8)' - } else { - return highlightLinks.has(link) ? 'purple' : 'rgb(50, 50, 50, 0.2)' - } - } - : (link) => - [ - '#ff665c', - '#e69055', - '#7bc275', - '#4db5bd', - '#FCCE7B', - '#51afef', - '#1f5582', - '#C57BDB', - '#a991f1', - '#5cEfFF', - '#6A8FBF', - ][gData.nodes[link.sourceIndex].index % 11] - } + linkColor={} linkDirectionalParticles={physics.particles} nodeLabel={(node) => node.title} linkWidth={(link) => |