summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas F. K. Jorna <[email protected]>2021-07-17 22:51:13 +0200
committerThomas F. K. Jorna <[email protected]>2021-07-17 22:51:13 +0200
commitd7fc87e0c0b6782f803fc90cd21a333340120d90 (patch)
treef68ea6031773f89253db965b61f9fb331915ecc1
parent6de4b3a6f24c5ff9d29e014589414cfecdb37b00 (diff)
just added so much, bad commit
-rw-r--r--app/components/graph/graph.tsx86
-rw-r--r--app/components/tweaks/tweaks.tsx44
-rw-r--r--app/screens/graph/graph-screen.tsx24
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]);
}