QB64 Phoenix Edition
A Lava Lamp to stare at. - Printable Version

+- QB64 Phoenix Edition (https://qb64phoenix.com/forum)
+-- Forum: QB64 Rising (https://qb64phoenix.com/forum/forumdisplay.php?fid=1)
+--- Forum: Code and Stuff (https://qb64phoenix.com/forum/forumdisplay.php?fid=3)
+---- Forum: Programs (https://qb64phoenix.com/forum/forumdisplay.php?fid=7)
+---- Thread: A Lava Lamp to stare at. (/showthread.php?tid=3079)

Pages: 1 2


A Lava Lamp to stare at. - Dav - 09-26-2024

Something kind of silly but was fun to make.   I started playing with some plasma code and it morphed into a lava lamp somehow.  Never had one in real life.

This runs slow on my older laptop - commenting out the _LIMIT 30 didn't speed it up at all for me.  So if the blobs and plasma go too fast for you on your modern PC, play with the t = TIMER * .7 line to adjust speed.

- Dav

Code: (Select All)
'============
'LAVALAMP.BAS
'============
'By Dav, SEP/2024 for QB64PE

Screen _NewImage(1000, 700, 32)

Do

    Cls

    t = Timer * .7 'control speed here

    'plasma background
    For y = 0 To _Height Step 2
        For x = 0 To _Width Step 2
            r = Int(128 + 127 * Sin((x * .01) + t))
            g = Int(128 + 127 * Sin((y * .01) + t * 1.2))
            b = Int(128 + 127 * Sin((x * .01) + (y * 0.01) + t * .8))
            Line (x, y)-Step(1, 1), _RGBA(r, g, b, 50), BF
        Next
    Next

    'oily plasma blobs
    For y = 50 To _Height - 51
        For x = 325 To 675
            disx = x - _Width \ 2
            dixy = y - _Height \ 2
            wav = Sin(t + dixy * .05 + disx * .05) * 35
            rad = 150 + 50 * Sin(t * 1.5 + dixy * .1) + wav
            pulse = 1 + .5 * Sin(t + dixy * .1)
            If Sqr(disx ^ 2 / (85 * pulse) ^ 2 + dixy ^ 2 / (rad * pulse) ^ 2) < 1 Then
                clr = Int(255 - Sqr(disx ^ 2 + dixy ^ 2) / 2)
                Line (x, y)-Step(1, 1), _RGBA(255, clr, clr / 3, 150), BF
            End If
        Next
    Next

    'draw top half of lamp
    For y = 50 To 350
        wfix = (350 - y) / 3
        Line (325 + wfix, y)-(675 - wfix, y), _RGBA(255, 255, 100, 50), BF
    Next
    'draw bottom half of lamp
    For y = 351 To 650
        wfix = (y - 351) / 3
        Line (325 + wfix, y)-(675 - wfix, y), _RGBA(255, 255, 100, 50), BF
    Next

    'lamp top
    Line (425, 20)-(575, 50), _RGB(150, 100, 0), BF
    Line (425, 20)-(575, 50), _RGBA(255, 255, 100, 75), B

    'lamp base
    Line (375, 650)-(625, 700), _RGB(150, 100, 0), BF
    Line (375, 650)-(625, 700), _RGBA(255, 255, 100, 75), B

    _Display
    _Limit 30

Loop Until InKey$ <> ""



RE: A Lava Lamp to stare at. - TerryRitchie - 09-26-2024

Hey that's cool! Now where did I put my bong?


RE: A Lava Lamp to stare at. - bplus - 09-26-2024

@Dav nice lighting effect! I missed it last night, too dark to see the lighting effect on the walls aound the lamp.

I like! I never had lava lamp either but I imagine this effect is realistic enough.


RE: A Lava Lamp to stare at. - Dav - 09-27-2024

Thanks, ya’ll. I may redo the lamp shape one day.  

I’ll be offline for a while again.  Storms/flood took out our internet line again.  They will have to run another new line.   Wish they would put it OVER the creek instead of through it.   Browsing from a coffee shop right now.

Hope our power at least comes on today.

- Dav


RE: A Lava Lamp to stare at. - TerryRitchie - 09-27-2024

(09-27-2024, 02:06 PM)Dav Wrote: Thanks, ya’ll. I may redo the lamp shape one day.  

I’ll be offline for a while again.  Storms/flood took out our internet line again.  They will have to run another new line.   Wish they would put it OVER the creek instead of through it.   Browsing from a coffee shop right now.

Hope our power at least comes on today.

- Dav
Stay safe. My son lives in Tampa and said the storm was a big one this time.


RE: A Lava Lamp to stare at. - Dav - 09-27-2024

Yep I hear it hit FL hard.  We visited Cedar Key, FL last summer, looks like it got nearly wiped out from the pictures I've seen.  We're in NC right now.  Lots of wind and rain, falling trees.  This coffee shop is packed with people who lost power and internet.    

- Dav


RE: A Lava Lamp to stare at. - SMcNeill - 09-27-2024

Flooding has never been an issue here, but I may end up offline for a few days just like Dav.   The issue we're facing is the dang winds this time around!  Living in the mountains, with the hills all straight up and down, the wind will knock down old trees and then those fall on top of the powerlines...  Which the electric guys then have to basically cut a road back into to fix.  (Or dangle those poor guys out in those helicopters who don't make enough money at a zillion dollars an hour for their job!)

We've had power flick off and on a dozen times already today.  I'm kinda imagining that power may just decided to die for good eventually before this mess passes us on by completely.


RE: A Lava Lamp to stare at. - Kernelpanic - 09-27-2024

Quote:The issue we're facing is the dang winds this time around!  Living in the mountains, with the hills all straight up and down, the wind will knock down old trees and then those fall on top of the powerlines...  Which the electric guys then have to basically cut a road back into to fix.
When I was in America over thirty years ago, I was amazed at the power cables that you could see everywhere on the streets. Technologically high advanced, and then something like that - like in a "Third world country".

Especially in rural areas like yours, it would be much cheaper to put the cables underground than to repair power cables every year.

An old picture from Cleveland Ohio. I could not do it any better now.

[Image: Stromkabel-USA1986.jpg]


RE: A Lava Lamp to stare at. - TerryRitchie - 09-27-2024

(09-27-2024, 04:21 PM)SMcNeill Wrote: Flooding has never been an issue here, but I may end up offline for a few days just like Dav.   The issue we're facing is the dang winds this time around!  Living in the mountains, with the hills all straight up and down, the wind will knock down old trees and then those fall on top of the powerlines...  Which the electric guys then have to basically cut a road back into to fix.  (Or dangle those poor guys out in those helicopters who don't make enough money at a zillion dollars an hour for their job!)

We've had power flick off and on a dozen times already today.  I'm kinda imagining that power may just decided to die for good eventually before this mess passes us on by completely.
The wind is reaching us all the way in NorthWest Ohio too. Windier than crap right now, about 40 to 50MPH gusts. Not enough to knock down trees but some huge limbs dropping on power lines could cause power to go at any time now. Gotta love living in a first world country with third world wiring. Smile


RE: A Lava Lamp to stare at. - bplus - 09-27-2024

I left my Lava Lamp on too long, it errupted:
Code: (Select All)
_Title "Lava Flow" 'bplus 2019-12-12 based on Lava 3.bas SmallBASIC 2015-04-25

'================================================================================
'                  Press Spacebar for slightly differnt lava effect
'================================================================================

Const xmax = 1200, ymax = 720, n = 800, bg = &HFF000000 '<< try different colors
Dim Shared x(1 To n), y(1 To n), xr(1 To n), yr(1 To n), c(1 To n) As _Unsigned Long
Screen _NewImage(xmax, ymax, 32)
_FullScreen
Randomize Timer
For i = 1 To n: new i, -1: Next 'init lava
Line (0, 0)-(xmax, ymax), bg, BF 'black'n screen
Do
    If InKey$ = " " Then toggle = 1 - toggle
    For i = 1 To n
        If toggle Then Color c(i) Else Color lavaColor~&
        fEllipse x(i), y(i), xr(i), yr(i)
        x(i) = x(i) + xr(i)
        y(i) = y(i) + (Int(Rnd * 3) - 1) * yr(i) + .1
        If x(i) > xmax Then new i, 0
        If y(i) < -5 Or y(i) > ymax + 5 Then new i, 0
    Next
    xp = Int(Rnd * (xmax - 5)) + 1
    yp = Int(Rnd * (ymax - 5)) + 1
    Paint (xp, yp), fire~&, bg
    If xp Mod 100 = 50 Or xp Mod 100 = 55 Then Paint (xp, yp), bg, bg
    _Limit 30
Loop Until _KeyDown(27)
System

Sub fEllipse (CX As Long, CY As Long, xRadius As Long, yRadius As Long)
    Dim scale As Single, x As Long, y As Long
    scale = yRadius / xRadius
    Line (CX, CY - yRadius)-(CX, CY + yRadius), , BF
    For x = 1 To xRadius
        y = scale * Sqr(xRadius * xRadius - x * x)
        Line (CX + x, CY - y)-(CX + x, CY + y), , BF
        Line (CX - x, CY - y)-(CX - x, CY + y), , BF
    Next
End Sub

Sub new (i, rndxTF)
    If rndxTF Then x(i) = Int(Rnd * (xmax - 10)) + 5 Else x(i) = Rnd * 10
    y(i) = Int(Rnd * (ymax - 10)) + 5
    xr(i) = Int(Rnd * 4) + 3
    yr(i) = Rnd * xr(i) * .5
    c(i) = lavaColor~&
End Sub

Function fire~&
    If Rnd < .25 Then fire~& = &HFF000000 Else fire~& = _RGB32(255, Rnd * 128 + 127, 0)
End Function

Function lavaColor~&
    r = Int(Rnd * 31)
    If r Mod 4 = 0 Then lavaColor = bg Else lavaColor~& = _RGB32(r / 30 * 128 + 127, Rnd * r / 45 * 255, 0)
End Function