hydra-nodegl 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,4 @@
1
+ # These are supported funding model platforms
2
+
3
+ github: Uchida16104
4
+ open_collective: Uchida16104
@@ -0,0 +1,38 @@
1
+ ---
2
+ name: Bug report
3
+ about: Create a report to help us improve
4
+ title: ''
5
+ labels: ''
6
+ assignees: ''
7
+
8
+ ---
9
+
10
+ **Describe the bug**
11
+ A clear and concise description of what the bug is.
12
+
13
+ **To Reproduce**
14
+ Steps to reproduce the behavior:
15
+ 1. Go to '...'
16
+ 2. Click on '....'
17
+ 3. Scroll down to '....'
18
+ 4. See error
19
+
20
+ **Expected behavior**
21
+ A clear and concise description of what you expected to happen.
22
+
23
+ **Screenshots**
24
+ If applicable, add screenshots to help explain your problem.
25
+
26
+ **Desktop (please complete the following information):**
27
+ - OS: [e.g. iOS]
28
+ - Browser [e.g. chrome, safari]
29
+ - Version [e.g. 22]
30
+
31
+ **Smartphone (please complete the following information):**
32
+ - Device: [e.g. iPhone6]
33
+ - OS: [e.g. iOS8.1]
34
+ - Browser [e.g. stock browser, safari]
35
+ - Version [e.g. 22]
36
+
37
+ **Additional context**
38
+ Add any other context about the problem here.
@@ -0,0 +1,10 @@
1
+ ---
2
+ name: Custom issue template
3
+ about: Describe this issue template's purpose here.
4
+ title: ''
5
+ labels: ''
6
+ assignees: ''
7
+
8
+ ---
9
+
10
+
@@ -0,0 +1,20 @@
1
+ ---
2
+ name: Feature request
3
+ about: Suggest an idea for this project
4
+ title: ''
5
+ labels: ''
6
+ assignees: ''
7
+
8
+ ---
9
+
10
+ **Is your feature request related to a problem? Please describe.**
11
+ A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]
12
+
13
+ **Describe the solution you'd like**
14
+ A clear and concise description of what you want to happen.
15
+
16
+ **Describe alternatives you've considered**
17
+ A clear and concise description of any alternative solutions or features you've considered.
18
+
19
+ **Additional context**
20
+ Add any other context or screenshots about the feature request here.
@@ -0,0 +1,62 @@
1
+ name: Release NodeGL
2
+
3
+ on:
4
+ push:
5
+ tags:
6
+ - 'v*'
7
+
8
+ permissions:
9
+ contents: write
10
+ packages: write
11
+
12
+ env:
13
+ PACKAGE_NAME: NodeGL
14
+ DESCRIPTION: "It'll be convenience for hydra used by Node.js."
15
+ MAIN: index.cjs
16
+ LICENSE: MIT
17
+
18
+ jobs:
19
+ build:
20
+ runs-on: ubuntu-latest
21
+ steps:
22
+ - name: Checkout repository
23
+ uses: actions/checkout@v4
24
+
25
+ - name: Setup Node.js
26
+ uses: actions/setup-node@v4
27
+ with:
28
+ node-version: 20
29
+
30
+ - name: Install dependencies and generate lockfile
31
+ run: |
32
+ rm -f package-lock.json
33
+ npm install
34
+ echo "🔐 Generated lockfile with updated integrity:"
35
+ cat package-lock.json
36
+
37
+ publish-gpr:
38
+ needs: build
39
+ runs-on: ubuntu-latest
40
+ permissions:
41
+ packages: write
42
+ contents: read
43
+ steps:
44
+ - name: Checkout repository
45
+ uses: actions/checkout@v4
46
+
47
+ - name: Setup Node.js for GitHub Package Registry
48
+ uses: actions/setup-node@v4
49
+ with:
50
+ node-version: 20
51
+ registry-url: https://npm.pkg.github.com/
52
+
53
+ - name: Authenticate with GitHub Package Registry
54
+ run: echo "//npm.pkg.github.com/:_authToken=${{ secrets.GITHUB_TOKEN }}" > ~/.npmrc
55
+
56
+ - name: Install from lockfile (with updated integrity)
57
+ run: npm ci
58
+
59
+ - name: Publish to GitHub Package Registry
60
+ env:
61
+ NODE_AUTH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
62
+ run: npm publish
package/README.md ADDED
@@ -0,0 +1,45 @@
1
+ # NodeGL
2
+
3
+ <p>It'll be convenience for <a href="https://hydra.ojack.xyz">hydra</a> used by Node.js.</p>
4
+ <img src="https://cdn.glitch.me/project-avatar/efd0d1ad-4977-47ea-a2d9-9ce05d4c70fa.png?2023-02-10T14:36:52.526Z"/>
5
+ <br>
6
+ <ul><h1>Usage</h1></ul>
7
+ <h3>First, please use the following code to read on hydra.</h3>
8
+ <pre><code>await loadScript("<a href="https://nodegl.glitch.me/function-list.js">https://nodegl.glitch.me/function-list.js</a>");</code></pre>
9
+ <ol><li><h5>When you'd like to change the canvas axis to "y" perspective.</h5></li>
10
+ <ul><li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTNCJTBBb3NjKCkuc2NhbGUoZ2xzbEF4aXMoJTIyeSUyMikpLm91dCgpJTNC">osc().scale(glslAxis("y")).out();</a></li></ul>
11
+ <ul><li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTNCJTBBdm9yb25vaSgyMCUyQzElMkM1KS5zY2FsZShnbHNsQXhpcyglMjIyeSUyMikpLm91dCgpJTNC">voronoi(20,1,5).scale(glslAxis("2y")).out();</a></li></ul>
12
+ <li><h5>It can be modulated using the difference between "solid" and "gradient" color changes.</h5></li>
13
+ <ul><li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTNCJTBBc3BlZWQlM0QxJTJGNCUzQiUwQWZsYXNoKDElMkMyJTJDMSkuZGlmZihvc2MoMzAlMkMxJTJGOCUyQzMwMCkuZGlmZihvc2MoMzAlMkMxJTJGOCUyQzMwMCkucm90YXRlKE1hdGguUEklMkYyKSkpLnNjYWxlKCU1QjElMkY0JTJDMSUyRjIlNUQuc21vb3RoKCkpLm91dCgpJTNC">speed=1/4;
14
+ <br>flash(1,2,1).diff(osc(30,1/8,300).diff(osc(30,1/8,300).rotate(Math.PI/2))).scale([1/4,1/2].smooth()).out();</a></li></ul>
15
+ <li><h5>You can also use functions that store trigonometric and inverse trigonometric functions to change the video.</h5></li>
16
+ <ul><li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTNCJTBBbm9pc2UoKS5yb3RhdGUoKCklM0QlM0VsaXN0KDElMkMyKSkub3V0KCklM0I%3D">noise().rotate(()=>list(1,2)).out();</a></li></ul>
17
+ <li><h5>The options available within hydra's "ease" function can also be easily specified.</h5></li>
18
+ <ul><li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTNCJTBBZ3JhZGllbnQoMSkuaHVlKCU1QjAlMkMxJTVELmVhc2UoZWFzZUluT3V0KDUpKSkub3V0KCklM0I%3D">gradient(1).hue([0,1].ease(easeInOut(5))).out();</a></li></ul>
19
+ <li><h5>Variables can be defined sequentially and the last variable among them can be used. (It can also be used outside of hydra.)</h5></li>
20
+ <ul><li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTNCJTBBb3NjKCkucm90YXRlKHZhckRlZiglMjJoeWRyYSUyMiUyQ01hdGguYXRhbiUyQzEwKSkub3V0KCklM0I%3D">osc().rotate(varDef("hydra",Math.atan,10)).out();</a></li></ul>
21
+ <li><h5>Two different functions can be entered, each increasing in a different step, and the results put into an array and modulated.</h5></li>
22
+ <ul><li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTNCJTBBc2hhcGUoZnVuY0FyeSg0JTJDNSUyQzYlMkMwLjA1JTJDMC4xJTJDTWF0aC50YW4lMkNNYXRoLnNpbikuc21vb3RoKCkpLm91dCgpJTNC">shape(funcAry(4,5,6,0.05,0.1,Math.tan,Math.sin).smooth()).out();</a></li></ul>
23
+ <li><h5>It can generate an array from 0 to a specified number and output a random value.</h5></li>
24
+ <ul><li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTNCJTBBc2hhcGUocmFuZEFyeSgxMDAlMkMwLjEpKS5vdXQoKSUzQg%3D%3D">shape(randAry(100,0.1)).out();</a></li></ul>
25
+ <li><h5>It can generate an array from 0 to a specified number, repeatedly output a random value, and store it in the array again.</h5></li>
26
+ <ul><li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTNCJTBBc2hhcGUoZ2VuQXJ5KDEwMCUyQzAuMSUyQzEwKS5zbW9vdGgoKSkub3V0KCklM0I%3D">shape(genAry(100,0.1,10).smooth()).out();</a></li></ul>
27
+ <li><h5>Four output videos can be looped and switched every specified number of seconds at specified speeds.</h5></li>
28
+ <ul><li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTNCJTBBc2V0TG9vcCgxJTJGMiUyQy0xJTJGNCUyQy0xJTJGMiUyQzElMkY0JTJDMTAwMCklM0IlMEFvc2MoKS5vdXQoKSUzQiUwQW5vaXNlKCkub3V0KG8xKSUzQiUwQWdyYWRpZW50KDEpLm91dChvMiklM0IlMEF2b3Jvbm9pKCkub3V0KG8zKSUzQg%3D%3D">setLoop(1/2,-1/4,-1/2,1/4,1000);<br>osc().out();<br>noise().out(o1);<br>gradient(1).out(o2);<br>voronoi().out(o3);</a></li></ul>
29
+ <li><h5>Others(form, pad, particle, rbga, hsb, rainbow and zebra)</h5></li>
30
+ <ul><li><a href="https://hydra.ojack.xyz/?sketch_id=Y27ApIAcbfmAlojw">form(4,2,0,1,15,1/8,0).colorama(3).luma().hue(()=>Math.sin(time/10),()=>Math.cos(time/10),()=>Math.tan(time/10)).diff(gradient(1)).invert().scale(Math.PI).repeat().out();</a></li>
31
+ <li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTBBcGFkKDEwJTJDbzAlMkM0JTJDMCUyQzElMkMuOTkpLmRpZmYob3NjKDElMkMyJTJDMzAwKS5kaWZmKGdyYWRpZW50KDEpKS5zY2FsZSguMSkpLmRpZmYocmdiYShvMCUyQzElMkMxJTJDMSUyQzEpKS5kaWZmKGhzYihvMCUyQzElMkMxJTJDMSUyRjQpKS5pbnZlcnQoKS5vdXQoKSUzQg%3D%3D">pad(10,o0,4,0,1,.99).diff(osc(1,2,300).diff(gradient(1)).scale(.1)).diff(rgba(o0,1,1,1,1)).diff(hsb(o0,1,1,1/4)).invert().out();</a></li>
32
+ <li><a href="https://hydra.ojack.xyz/?sketch_id=N31iJkJbyMGUnAOT">gradient().blend(rainbow(3)).out();</a>
33
+ <li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTBBb3NjKDElMkMyJTJDMzAwKS5kaWZmKGdyYWRpZW50KDEpKS5zY2FsZSguMSkuZGlmZihwYXJ0aWNsZShvMCUyQy45OSkpLmludmVydCgpLm91dCgpJTNC">osc(1,2,300).diff(gradient(1)).scale(.1).diff(particle(o0,.99)).invert().out();</a></li>
34
+ <li><a href="https://hydra.ojack.xyz/?code=YXdhaXQlMjBsb2FkU2NyaXB0KCUyMmh0dHBzJTNBJTJGJTJGbm9kZWdsLmdsaXRjaC5tZSUyRmZ1bmN0aW9uLWxpc3QuanMlMjIpJTBBczAuaW5pdENhbSgpJTNCJTBBc29saWQoKS5hZGQoemVicmEoc3JjKHMwKSUyQyUyMDIlMkMlMjA0JTJDJTIwTWF0aC5zaW4lMkMlMjAwLjEpKS5vdXQoKSUzQg%3D%3D">s0.initCam();<br>solid().add(zebra(src(s0), 2, 4, Math.sin, 0.1)).out();</a></li></ul>
35
+ </ol>
36
+ <br>
37
+ <p>Click <a href="https://nodegl.glitch.me/function-list.js">here</a> for more information.</p>
38
+ <p>I appreciate all hydra users or developers on <a href="https://github.com/hydra-synth">GitHub</a>, <a href="https://www.facebook.com/groups/1084288351771117/">FB</a>, <a href="https://twitter.com/hydra_patterns">Twitter</a> or <a href="https://discord.gg/Mv9kXwtwVH">Discord</a>, etc...</p>
39
+ <p>By Hirotoshi Uchida<br><a href="https://hearthis.at/hirotoshi-uchida-2nd/">hearthis.at</a><br><a href="https://www.instagram.com/hirotoshiuchida/">IG</a></p>
40
+ <h1>Log</h1>
41
+ <h2>First commited as "NodeBook"</h2>
42
+ <p>on Jan 19th, 2023.</p>
43
+ <h2>Released the newest</h2>
44
+ <p>on Apr 29th, 2025.</p>
45
+ <h6><a href="https://github.com/Uchida16104/NodeGL/commits/main/README.md">Show more</a></h6>