diff options
author | Thomas F. K. Jorna <[email protected]> | 2021-07-17 22:51:13 +0200 |
---|---|---|
committer | Thomas F. K. Jorna <[email protected]> | 2021-07-17 22:51:13 +0200 |
commit | d7fc87e0c0b6782f803fc90cd21a333340120d90 (patch) | |
tree | f68ea6031773f89253db965b61f9fb331915ecc1 /app | |
parent | 6de4b3a6f24c5ff9d29e014589414cfecdb37b00 (diff) |
just added so much, bad commit
Diffstat (limited to 'app')
-rw-r--r-- | app/components/graph/graph.tsx | 86 | ||||
-rw-r--r-- | app/components/tweaks/tweaks.tsx | 44 | ||||
-rw-r--r-- | app/screens/graph/graph-screen.tsx | 24 |
3 files changed, 124 insertions, 30 deletions
diff --git a/app/components/graph/graph.tsx b/app/components/graph/graph.tsx index 14de37a..a4e91f2 100644 --- a/app/components/graph/graph.tsx +++ b/app/components/graph/graph.tsx @@ -11,7 +11,7 @@ import { flatten } from "ramda" //import rando from "../../data/rando.json" import { ForceGraph2D, ForceGraph3D, ForceGraphVR, ForceGraphAR } from "react-force-graph" -import * as d3 from "d3-force" +import * as d3 from "d3-force-3d" const CONTAINER: ViewStyle = { justifyContent: "center", @@ -51,8 +51,16 @@ export const Graph = observer(function Graph(props: GraphProps): JSX.Element { useEffect(() => { const fg = fgRef.current - //fg.d3Force('center').strength(0.05); + if(physics.gravityOn){ + fg.d3Force("x", d3.forceX().strength(physics.gravity)); + fg.d3Force("y", d3.forceY().strength(physics.gravity)); + physics.threedim ? fg.d3Force("z", d3.forceZ().strength(physics.gravity)) : null; + } else { + fg.d3Force("x", null); + fg.d3Force("y", null); + physics.threedim ? fg.d3Force("z", null) : null; + }; fg.d3Force("link").strength(physics.linkStrength) fg.d3Force("link").iterations(physics.linkIts) physics.collision @@ -132,6 +140,7 @@ export const Graph = observer(function Graph(props: GraphProps): JSX.Element { }; const handleNodeHover = node => { + console.log("hover"); highlightNodes.clear(); highlightLinks.clear(); if (node) { @@ -187,10 +196,34 @@ export const Graph = observer(function Graph(props: GraphProps): JSX.Element { autoPauseRedraw={false} graphData={gData} //graphData={physics.collapse ? prunedTree : gData} - nodeAutoColorBy="id" - linkAutoColorBy="target" + nodeAutoColorBy={physics.colorful ? "id" : undefined} + 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.childLinks.length ? "green" : node.collapsed ? "red" : "yellow" + }) : undefined + } + linkAutoColorBy={physics.colorful ? "target" : undefined} //linkAutoColorBy={(d) => gData.nodes[d.source].id % GROUPS} - linkColor="#ffffff" + 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)" + } + // !node.childLinks.length ? "green" : node.collapsed ? "red" : "yellow" + } + ) : undefined + //highlightLinks.has(link) ? "purple" : "grey" + // !node.childLinks.length ? "green" : node.collapsed ? "red" : "yellow" + } linkDirectionalParticles={physics.particles} //onNodeClick={!physics.collapse ? null : handleNodeClick} nodeLabel={(node) => node.title} @@ -199,24 +232,27 @@ export const Graph = observer(function Graph(props: GraphProps): JSX.Element { linkWidth={link => highlightLinks.has(link) ? 3 * physics.linkWidth : physics.linkWidth} linkOpacity={physics.linkOpacity} nodeRelSize={physics.nodeRel} - nodeVal={node => highlightNodes.has(node) ? 10 : 5} + nodeVal={node => 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 ) { + 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, fontSize].map(n => n + fontSize * 0.2); // some padding + 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, ' + Math.min((globalScale - physics.labelScale)/physics.labelScale, 1) + ')'; + ctx.fillStyle = 'rgba(20, 20, 20, ' + + (highlightNodes.size === 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, ' + Math.min(3*(globalScale - physics.labelScale)/physics.labelScale, 1) + ')'; + 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 @@ -224,32 +260,44 @@ export const Graph = observer(function Graph(props: GraphProps): JSX.Element { }; }} nodeCanvasObjectMode={()=> 'after'} - onNodeHover={handleNodeHover} - onLinkHover={handleLinkHover} + onNodeHover={physics.hover ? handleNodeHover : null} + //onLinkHover={physics.hover ? handleLinkHover : null} + d3AlphaDecay={physics.alphaDecay} + d3AlphaMin={physics.alphaTarget} + d3VelocityDecay={physics.velocityDecay} /> ) : ( <ForceGraph3D ref={fgRef} graphData={gData} - nodeAutoColorBy="group" //graphData={physics.collapse ? prunedTree : gData} // nodeAutoColorBy={d => d.id%GROUPS} - //linkAutoColorBy={(d) => gData.nodes[d.source].id % GROUPS} - linkColor="#ffffff" - linkWidth={2} + linkWidth={physics.linkWidth} linkDirectionalParticles={physics.particles} - //nodeColor={(node) => + nodeColor={(node) => + highlightNodes.has(node) ? "purple" : "grey" // !node.childLinks.length ? "green" : node.collapsed ? "red" : "yellow" - //} + } + linkColor={(link) => + highlightLinks.has(link) ? "purple" : "grey" + // !node.childLinks.length ? "green" : node.collapsed ? "red" : "yellow" + } //onNodeClick={!physics.collapse ? null : handleNodeClick} nodeLabel={node => node.title} //nodeVal={(node) => node.childLinks.length + 1} //d3VelocityDecay={visco} - linkWidth={physics.linkWidth} + //linkWidth={link => highlightLinks.has(link) ? 3 * physics.linkWidth : physics.linkWidth} + //linkWidth={link => highlightLinks.has(link) ? 3 * physics.linkWidth : physics.linkWidth} linkOpacity={physics.linkOpacity} nodeRelSize={physics.nodeRel} + //nodeVal={node => highlightNodes.has(node) ? 10 : 5} linkDirectionalParticleWidth={physics.particleWidth} backgroundColor="#1d1d1d" + onNodeHover={physics.hover ? handleNodeHover : null} + onLinkHover={physics.hover ? handleLinkHover : null} + d3AlphaDecay={physics.alphaDecay} + d3AlphaMin={physics.alphaTarget} + d3VelocityDecay={physics.velocityDecay} /> )} </View> diff --git a/app/components/tweaks/tweaks.tsx b/app/components/tweaks/tweaks.tsx index e235ad4..8913e98 100644 --- a/app/components/tweaks/tweaks.tsx +++ b/app/components/tweaks/tweaks.tsx @@ -41,6 +41,18 @@ export const Tweaks = observer(function Tweaks(props: TweaksProps): JSX.Element title: "Physics", content: <View> + <Text preset="fieldLabel" text="Gravity" /> + <Switch style={{ width: "5", height: 20, marginVertical: 10 }} + value={physics.gravityOn} + onValueChange={() => { setPhysics({ ...physics, gravityOn: !physics.gravityOn })}} + /> + <Text preset="fieldLabel" text={"Gravity: " + physics.gravity} /> + <Slider style={{ height: 40, width: "90%" }} + minimumValue={0} + maximumValue={1} + onValueChange={(value) => { setPhysics({ ...physics, gravity: value }) }} + value={physics.gravity} + step={0.01} /> <Text preset="fieldLabel" text={"Repulsive force: " + physics.charge} /> <Slider style={{ height: 40, width: "90%" }} minimumValue={-400} @@ -68,12 +80,44 @@ export const Tweaks = observer(function Tweaks(props: TweaksProps): JSX.Element value={physics.collision} onValueChange={() => { setPhysics({ ...physics, collision: !physics.collision }) }} /> + <Text preset="fieldLabel" text={"Alhpa Decay: " + physics.alphaDecay} /> + <Slider style={{ height: 40, width: "90%" }} + minimumValue={0} + maximumValue={1} + onValueChange={(value) => { setPhysics({ ...physics, alphaDecay: value }) }} + value={physics.alphaDecay} + step={.01} /> + <Text preset="fieldLabel" text={"Alhpa Target: " + physics.alphaTarget} /> + <Slider style={{ height: 40, width: "90%" }} + minimumValue={0} + maximumValue={1} + onValueChange={(value) => { setPhysics({ ...physics, alphaTarget: value }) }} + value={physics.alphaTarget} + step={0.1} + /> + <Text preset="fieldLabel" text={"Viscosity: " + physics.velocityDecay} /> + <Slider style={{ height: 40, width: "90%" }} + minimumValue={0} + maximumValue={1} + onValueChange={(value) => { setPhysics({ ...physics, velocityDecay: value }) }} + value={physics.velocityDecay} + step={0.01} /> </View>, }, { title: 'Visual', content: <View> + <Text preset="fieldLabel" text="Colorful" /> + <Switch style={{ width: "5", height: 20, marginVertical: 10 }} + value={physics.colorful} + onValueChange={() => { setPhysics({ ...physics, colorful: !physics.colorful })}} + /> + <Text preset="fieldLabel" text="Hover highlight" /> + <Switch style={{ width: "5", height: 20, marginVertical: 10 }} + value={physics.hover} + onValueChange={() => { setPhysics({ ...physics, hover: !physics.hover })}} + /> <Text preset="fieldLabel" text={"Line Opacity: " + physics.linkOpacity} /> <Slider style={{ height: 40, width: "90%" }} minimumValue={0} diff --git a/app/screens/graph/graph-screen.tsx b/app/screens/graph/graph-screen.tsx index 6a01927..008e53b 100644 --- a/app/screens/graph/graph-screen.tsx +++ b/app/screens/graph/graph-screen.tsx @@ -35,19 +35,26 @@ export const GraphScreen = observer(function GraphScreen() { const [nodeIds, setNodeIds] = useState([]); // { "nodes": [{ "id": 1 }, { "id": 2 }], "links": [{ "target": 1, "source": 2 }] }); const physicsInit = { - charge: -30, - collision: false, - linkStrength: 1, + charge: -350, + collision: true, + linkStrength: .1, linkIts: 1, collapse: false, threedim: false, particles: 2, linkOpacity: 1, linkWidth: 1, - particleWidth: 1, - nodeRel: 1, + particleWidth: 4, + nodeRel: 4, labels: true, - labelScale: 1, + labelScale: 1.5, + alphaDecay: 0.16, + alphaTarget: 0.01, + velocityDecay: 0.25, + gravity: 0.5, + gravityOn: true, + hover: true, + colorful: true, } const getData = async () => { @@ -69,7 +76,6 @@ export const GraphScreen = observer(function GraphScreen() { try { const jsonValue = JSON.stringify(value) await AsyncStorage.mergeItem("@physics", jsonValue) - console.log("Writing " + jsonValue) } catch (e) { console.log(e) } @@ -85,7 +91,6 @@ export const GraphScreen = observer(function GraphScreen() { const timer = setTimeout(() => { storeData(physics) const test = getData() - console.log(test) }, 1000) return () => clearTimeout(timer) }, [physics]); @@ -117,9 +122,6 @@ export const GraphScreen = observer(function GraphScreen() { }; }; if (target && source) { - console.log(link); - console.log("target" + target); - console.log("source" + source); data.nodes[target[1]].neighbors.push(source[0]); data.nodes[source[1]].neighbors.push(target[0]); } |