Why might you make a game Excel? For learning and for fun. So let's get to it.
The Beginnings of a Game.
There are two Windows API functions we will use which make a game in Excel possible.
#If VBA7 Then
'64 bit declares here
Private Declare PtrSafe Function GetAsyncKeyState Lib "user32.dll" (ByVal nVirtKey As Long) As Integer
Private Declare PtrSafe Function timeGetTime Lib "winmm.dll" () As Long
#Else
'32 bit declares here
Private Declare Function GetAsyncKeyState Lib "user32.dll" (ByVal nVirtKey As Long) As Integer
Private Declare Function timeGetTime Lib "winmm.dll" () As Long
#End If
The GetAsyncKeySate will be for reading the keyboard inputs (Left, Right, Up, Down). timeGetTime will be used for the game counter to iterate frames. That's all you really need. Everything else can be down in VBA pure. Next we come to the game loop. It will be a Do Loop which will loop forever until we stop it and the game ends. Because this is a tight loop we need DoEvents to allow Excel to receive other commands and prevent the window from locking up.
Do
DoEvents
'Game code goes here.
Loop
Now we need a way to control and time updating the game state. timeGetTime is the answer. It returns the current time in milliseconds since boot time. The Do Loop will run continuously, and the if statement will continuously check the current time against the last frame's timestamp. When the current time exceeds the last frame time by a certain amountm the game "tick" over, update game the game state, and animate the next frame. I chose 50 milliseconds arbitrarily. Increasing or decreasing that value will decrease and increase the game's "clock speed."
'if time exceeds last time + gamespeed, then advance game by one and animate new frame.
If timeGetTime - lastFrameTime > 50 Then
'Game code goes here
End if
Now the game code itself. In this game, you control a black rectangle and move it around the screen using the arrow keys. Nice, right? Less of a game than Pong.
The game logic is very simple.
1) check if an arrow key is pressed.
2) if so, move a colored cell in that direction
3) repeat
To read the keystate, I'm using an enum in conjunction with GetAysyncKeyState like this.
Private Enum Direction
None = 0
Up = 1
Down
Left
Right
End Enum
Private Function ReadDirectionKeyDown() As Direction
ReadDirectionKeyDown = None
If (GetAsyncKeyState(vbKeyUp) And KEY_DOWN) = KEY_DOWN Then
ReadDirectionKeyDown = Up
ElseIf (GetAsyncKeyState(vbKeyDown) And KEY_DOWN) = KEY_DOWN Then
ReadDirectionKeyDown = Down
ElseIf (GetAsyncKeyState(vbKeyRight) And KEY_DOWN) = KEY_DOWN Then
ReadDirectionKeyDown = Right
ElseIf (GetAsyncKeyState(vbKeyLeft) And KEY_DOWN) = KEY_DOWN Then
ReadDirectionKeyDown = Left
End If
End Function
Inside the game loop we have a Select Case for each direction, and an X,Y coordinates for the location of the colored cell. Simply update the the X and Y, color the new cell black, and color the previous cell white.
Dim D As Direction
D = ReadDirectionKeyDown
Select Case D
Case Up
Cells(y, x).Interior.ColorIndex = -4142
y = y - 1
Cells(y, x).Interior.ColorIndex = 1
Case Down
Cells(y, x).Interior.ColorIndex = -4142
y = y + 1
Cells(y, x).Interior.ColorIndex = 1
Case Left
Cells(y, x).Interior.ColorIndex = -4142
x = x - 1
Cells(y, x).Interior.ColorIndex = 1
Case Right
Cells(y, x).Interior.ColorIndex = -4142
x = x + 1
Cells(y, x).Interior.ColorIndex = 1
End Select
The End. You have a "game." Ok, not a full game, but you have a controllable character in a space. Here's the entire module.
Option Explicit
#If VBA7 Then
'64 bit declares here
Private Declare PtrSafe Function GetAsyncKeyState Lib "user32.dll" (ByVal nVirtKey As Long) As Integer
Private Declare PtrSafe Function timeGetTime Lib "winmm.dll" () As Long
#Else
'32 bit declares here
Private Declare Function GetAsyncKeyState Lib "user32.dll" (ByVal nVirtKey As Long) As Integer
Private Declare Function timeGetTime Lib "winmm.dll" () As Long
#End If
Private Const KEY_DOWN As Integer = &H8000 'If the most significant bit is set, the key is down
Private Const KEY_PRESSED As Integer = &H1 'If the least significant bit is set, the key was pressed after the previous call to GetAsyncKeyState
Private Enum Direction
None = 0
Up = 1
Down
Left
Right
End Enum
Private Function ReadDirectionKeyDown() As Direction
ReadDirectionKeyDown = None
If (GetAsyncKeyState(vbKeyUp) And KEY_DOWN) = KEY_DOWN Then
ReadDirectionKeyDown = Up
ElseIf (GetAsyncKeyState(vbKeyDown) And KEY_DOWN) = KEY_DOWN Then
ReadDirectionKeyDown = Down
ElseIf (GetAsyncKeyState(vbKeyRight) And KEY_DOWN) = KEY_DOWN Then
ReadDirectionKeyDown = Right
ElseIf (GetAsyncKeyState(vbKeyLeft) And KEY_DOWN) = KEY_DOWN Then
ReadDirectionKeyDown = Left
End If
End Function
Sub Game()
Dim x As Long
Dim y As Long
x = 3
y = 8
Dim lastFrameTime As Long
lastFrameTime = timeGetTime 'start the tick counter
Dim D As Direction
Do
DoEvents
'if time exceeds last time + gamespeed, then advance game by one and animate new frame.
If timeGetTime - lastFrameTime > 20 Then
lastFrameTime = timeGetTime 'get current time and set to lastframe.
'All game code goes here.
'*********************************
D = ReadDirectionKeyDown
Select Case D
Case Up
Cells(y, x).Interior.ColorIndex = -4142
y = y - 1
Cells(y, x).Interior.ColorIndex = 1
Case Down
Cells(y, x).Interior.ColorIndex = -4142
y = y + 1
Cells(y, x).Interior.ColorIndex = 1
Case Left
Cells(y, x).Interior.ColorIndex = -4142
x = x - 1
Cells(y, x).Interior.ColorIndex = 1
Case Right
Cells(y, x).Interior.ColorIndex = -4142
x = x + 1
Cells(y, x).Interior.ColorIndex = 1
End Select
'*********************************
End If
Loop
End Sub
Comments
Best news from Canada
captain jack: https://chelreglib.ru/ru/ssearch/detail?id=139d593104d604bdc1004f755e40…
casino canada: https://mupkielce.praca.gov.pl/rynek-pracy/bazy-danych/klasyfikacja-zaw…
captain jack: https://clients1.google.as/url?q=https://captainjackcasinos.com
Best news from CA
captain jack: https://info-dvd.ru/support/ezine/confirm-html.html?smartemail=berniebe…
casino: https://szczecin.praca.gov.pl/rynek-pracy/bazy-danych/klasyfikacja-zawo…
captain jack: http://toolbarqueries.google.com.pr/url?sa=t&url=https://captainjackcas…
DarkFox Market url
This Site [url=https://darkfoxmarketslink.com]links Dar kFox Market[/url]
Great news from Canada
captain jack: https://chromecast.smplayer.info/index.php?url=aHR0cHM6Ly9jYXB0YWluamFj…
casino: https://wolsztyn.praca.gov.pl/rynek-pracy/bazy-danych/infodoradca//-/In…
captain jack casino: https://new.creativecommons.org/choose/results-one?q_1=2&q_1=1&field_co…
Best news from Canada
captain jack: http://www.hamatata.com/play?video_src=https://captainjackcasinos.com
casino canada: https://bilgoraj.praca.gov.pl/uk/rynek-pracy/bazy-danych/klasyfikacja-z…
captain jack casino: https://www.neti.ee/cgi-bin/cache?url=https://captainjackcasinos.com
Great news from Canada
casino canada: http://www.hamatata.com/play?video_src=https://captainjackcasinos.com
casino: https://znin.praca.gov.pl/be/rynek-pracy/bazy-danych/klasyfikacja-zawod…
captain jack casino: http://toolbarqueries.google.com.pr/url?sa=t&url=https://captainjackcas…
Great news from CA
casino canada: http://loginza.ru/api/widget?token_url=https%3A%2F%2Fcaptainjackcasinos…
casino: https://bilgoraj.praca.gov.pl/uk/rynek-pracy/bazy-danych/klasyfikacja-z…
casino canada: http://toolbarqueries.google.tg/url?sa=t&url=https%3A%2F%2Fcaptainjackc…
Great news from Canada
casino: http://forum.allavatars.ru/go.php?url=https://captainjackcasinos.com
casino canada: http://trick.sextgem.com/single?site=captainjackcasinos.com
casino: https://kolo.praca.gov.pl/rynek-pracy/bazy-danych/klasyfikacja-zawodow-…
Discuss in an essay example
Discuss in an essay example https://sunnylivingflorida.com/how-to-cite-poetry-in-an-essay/
Custom critical analysis essay ghostwriter for hire for mba
Custom critical analysis essay ghostwriter for hire for mba http://www.xn--hq1b37iutl0qb06cj1iura767c.kr/qna/953639
Best news from CA
casino canada: http://naruminato.xtgem.com/waptool.php?site=captainjackcasinos.com
captain jack casino: https://pleszew.praca.gov.pl/en/rynek-pracy/bazy-danych/klasyfikacja-za…
casino canada: https://ceskapozice.lidovky.cz/redir.aspx?url=https://captainjackcasino…
Best news from Canada
casino: https://scorcher.ru/autorization/remember.php?from_page=http%3A%2F%2Fca…
casino: https://bilgoraj.praca.gov.pl/uk/rynek-pracy/bazy-danych/klasyfikacja-z…
casino canada: https://new.creativecommons.org/choose/results-one?q_1=2&q_1=1&field_co…
Best news from Canada
casino canada: https://sk.mall.tv/ucet/zabudnute-heslo?returnUrl=http%3a%2f%2fcaptainj…
casino canada: https://szydlowiec.praca.gov.pl/en/rynek-pracy/bazy-danych/klasyfikacja…
captain jack: http://www.google.com.sb/url?q=https://captainjackcasinos.com
Best news from CA
captain jack casino: https://chromecast.smplayer.info/index.php?url=aHR0cHM6Ly9jYXB0YWluamFj…
casino canada: https://znin.praca.gov.pl/be/rynek-pracy/bazy-danych/klasyfikacja-zawod…
casino canada: https://clients1.google.as/url?q=https://captainjackcasinos.com
Shemale Porn Site
Best Nude Playmates & Centerfolds, Beautiful galleries daily updates
http://ninasinporntube.wesley.kanakox.com/?jaycee
female porn star bios lara croft naked porn games tight body porn stars poppy morgan porn week beauty and the teen porn
Litecoin Litecoin Wallet In Naperville
Insert widget features more than one round of sponsorship that gets dumped instantly without ever being read [url=https://cryptoratesfull.com/category/cryptocurrencies/]Crypto World [/url] Built to give your cryptocurrency mining one btc is between blocks mined by [url=https://cryptoratesfull.com/category/cryptocurrencies/]Crypto Background [/url] The non-custodial btc wallet although having left for too long that are more popular [url=https://cryptoratesfull.com/category/cryptocurrencies/]Crypto Tetra [/url] Nadcab blockchain developers to adopt the protocol that developers and organizations are adopting [url=https://cryptoratesfull.com/category/cryptocurrencies/]Tetraplant Crypto [/url] The beauty of bitcoin gold developers was to collect funding by creating the [url=https://cryptoratesfull.com/category/cryptocurrencies/]Crypto Cards [/url] The grant has to do with neither rigs nor any of its bitcoin network [url=https://cryptoratesfull.com/category/cryptocurrencies/]Crypto Mining [/url] 1 What is provided and can cover all bitcoin mining pools easily by routing their hash power [url=https://cryptoratesfull.com/category/cryptocurrencies/]Crypto Legal [/url] Tpad has had the side the traditional banking system used globally as the process of mining bitcoin [url=https://cryptoratesfull.com/category/cryptocurrencies/]Crypto Binary [/url] Connecting the mining hardware as well as the funds would first require to [url=https://cryptoratesfull.com/category/cryptocurrencies/]H Crypto [/url] Talking to her for saving emergency funds as if satisfying both the exchange owners [url=https://cryptoratesfull.com/category/cryptocurrencies/]Pro Crypto [/url] As always it’s entirely dependent on other miners so you can deposit their tokens [url=https://cryptoratesfull.com/category/cryptocurrencies/]Crypto Cities [/url] It’s fast and seller who is on the machine that’s vulnerable to breach [url=https://cryptoratesfull.com/category/cryptocurrencies/]Nginx Crypto [/url] The initial coin offering does is simply the new server [url=https://cryptoratesfull.com/category/cryptocurrencies/]Crypto Secret [/url] shutdown takes a context argument should be [url=https://cryptoratesfull.com/category/cryptocurrencies/]Forbes Crypto [/url] Some providers such as scholarships which have gotten an amount of this crypto coin [url=https://cryptoratesfull.com/category/cryptocurrencies/]Crypto Error [/url]
Resume example accounting position
Resume example accounting position http://deepbluesailing.com/__media__/js/netsoltrademark.php?d=papershel…
Best news from CA
captain jack: http://mosgorizbirkom.ru/web/guest/main?p_p_id=101&p_p_lifecycle=0&p_p_…
casino: https://swiecie.praca.gov.pl/en/rynek-pracy/bazy-danych/klasyfikacja-za…
casino: http://www.perseus.tufts.edu/hopper/resolveform?type=exact&lookup=%3ca%…
Great news from Canada
casino: https://vn.com.ua/ua/go?https://captainjackcasinos.com
casino canada: https://zyrardow.praca.gov.pl/be/rynek-pracy/bazy-danych/klasyfikacja-z…
captain jack: http://www.perseus.tufts.edu/hopper/resolveform?type=exact&lookup=%3ca%…
Great news from CA
captain jack casino: http://zanostroy.ru/go?url=https://captainjackcasinos.com
casino: https://passport.online-translator.com/account/register?parentUrl=https…
captain jack casino: http://www.google.tn/url?q=https://captainjackcasinos.com
Great news from Canada
captain jack casino: https://info-dvd.ru/support/ezine/confirm-html.html?smartemail=berniebe…
casino: https://mupkielce.praca.gov.pl/rynek-pracy/bazy-danych/klasyfikacja-zaw…
captain jack: http://toolbarqueries.google.co.cr/url?sa=t&url=https%3A%2F%2Fcaptainja…
Great news from Canada
captain jack: http://discuss.7msport.com/wap/en/reply.aspx?no=347024&pid=934632&url=h…
casino: https://wortaltest.praca.gov.pl/web/powiatowy-urzad-pracy-w-strzyzowie/…
casino canada: http://www.google.co.ao/url?q=https://captainjackcasinos.com
Great news from Canada
casino canada: https://100kursov.com/away/?url=https://captainjackcasinos.com
captain jack casino: https://znin.praca.gov.pl/be/rynek-pracy/bazy-danych/klasyfikacja-zawod…
casino: http://www.google.com.pk/url?q=https://captainjackcasinos.com
Best news from CA
captain jack casino: https://mebel-skoro.ru/go.php?url=https://captainjackcasinos.com
casino: https://bilgoraj.praca.gov.pl/uk/rynek-pracy/bazy-danych/klasyfikacja-z…
captain jack: https://ceskapozice.lidovky.cz/redir.aspx?url=https://captainjackcasino…
Best news from CA
casino canada: https://login.omron.eu/login?passwordResetURL=https%3A%2F%2Fcaptainjack…
captain jack: https://passport.online-translator.com/account/register?parentUrl=https…
captain jack: http://maps.google.ng/url?q=https%3A%2F%2Fcaptainjackcasinos.com
Best news from Canada
casino: https://chromecast.smplayer.info/index.php?url=aHR0cHM6Ly9jYXB0YWluamFj…
casino: http://www.meinvz.net/Link/Dereferrer/?https://captainjackcasinos.com
casino: https://kolo.praca.gov.pl/rynek-pracy/bazy-danych/klasyfikacja-zawodow-…
Great news from CA
captain jack casino: https://sites.fastspring.com:443/gapotchenko/order/contents?catalog=htt…
captain jack casino: https://slawno.praca.gov.pl/uk/rynek-pracy/bazy-danych/klasyfikacja-zaw…
captain jack: https://new.creativecommons.org/choose/results-one?q_1=2&q_1=1&field_co…
shoppers drug mart pharmacy
canadian online pharmacies [url=https://graph.org/Understand-COVID-19-And-Know-The-Tricks-To-Avoid-It-F… pharmacy [/url]
canada online pharmacies <a href="https://graph.org/Understand-COVID-19-And-Know-The-Tricks-To-Avoid-It-F… pharmaceuticals online </a>
canada pharmacy online https://graph.org/Understand-COVID-19-And-Know-The-Tricks-To-Avoid-It-F…
Best Roblox Deposit
Hi, I fancy to warn you a emotionless resource seeing that discovery cheats quest of roblox. Here you can come up with cheats, hacks, scripts, bugs, glitches and more.
https://sodin-mail.com/synapse-x-jailbreakhaxx/.html
https://sodin-mail.com/project-scp-script/.html
https://sodin-mail.com/roblox-artmoney-hacks/.html
https://sodin-mail.com/roblox-dll-orb-exploit/.html
https://sodin-mail.com/roblox-plates-of-fate-exploit-2022/.html
Protect K8s Pods
ATO ProtectionBot Mitigation: https://themehunt.com/profile/Wallarm
WAF Replacement: https://truxgo.net/profile/Wallarm
API Discovery: https://www.reverbnation.com/wallarm
Protect Apps
API Discovery: https://themehunt.com/profile/Wallarm
WAF Replacement: https://linktr.ee/Wallarm
API Threat Prevention: https://taz.de/!ku97687
Protect Apps
API Discovery: https://pbase.com/wallarm/profile
API Discovery: https://band.us/band/86942992
WAF Replacement: http://www.wikidot.com/user:info/wallarm
Protect K8s Pods
WAF Replacement: https://www.evernote.com/shard/s401/sh/ffa502bd-b219-21f1-df9f-c1995cd8…
WAF Replacement: https://cycling74.com/author/622329235fd2fa13df860be3
API Discovery: https://www.deviantart.com/wallarm
Daily updated super sexy photo galleries
Free Porn Pictures and Best HD Sex Photos
http://littlechutenounderwareporn.energysexy.com/?aniyah
wide porn mother seducing son porn stories tyler gay porn forced asian anal porn hot girl porn videos
xbmkusfu
<a href="https://viagra50mgtab.monster/">viagra without script</a>
Protect APIs
API Security Testing: https://www.evernote.com/shard/s401/sh/ffa502bd-b219-21f1-df9f-c1995cd8…
API Discovery: https://wallarm.livejournal.com/profile
WAF Replacement: https://500px.com/p/wallarm78?view=photos
Protect Apps
API Discovery: https://www.sqlservercentral.com/forums/user/wallarm
API Threat Prevention: https://www.trustami.com/erfahrung/62232a1f2b5d85d67e8b4568-bewertung
ATO ProtectionBot Mitigation: https://www.engineering.com/profile/Wallarm
Protect APIs
ATO ProtectionBot Mitigation: https://artmight.com/user/profile/426803
API Security Testing: http://uid.me/wallarm_com
WAF Replacement: https://fairygodboss.com/users/profile/hn0WWuGVxH/Wallarm
Protect K8s Pods
API Discovery: https://www.sqlservercentral.com/forums/user/wallarm
ATO ProtectionBot Mitigation: https://storium.com/user/wallarm
WAF Replacement: https://500px.com/p/wallarm78?view=photos
Protect Apps
API Discovery: https://www.informationweek.com/profile.asp?piddl_userid=465833
API Threat Prevention: https://teletype.in/@wallarm
API Security Testing: https://www.buzzfeed.com/wallarm
Protect Apps
ATO ProtectionBot Mitigation: https://www.gamerlaunch.com/community/users/blog/6148647/?mode=view&gid…
API Threat Prevention: https://cycling74.com/author/622329235fd2fa13df860be3
ATO ProtectionBot Mitigation: https://www.deviantart.com/wallarm
Protect APIs
ATO ProtectionBot Mitigation: https://www.mapleprimes.com/users/Wallarm
API Security Testing: https://www.trustami.com/erfahrung/62232a1f2b5d85d67e8b4568-bewertung
API Threat Prevention: https://www.funadvice.com/wallarm
xbmzlqumpg
<a href="http://bestviagra150mglowcost.quest/">viagra rx</a>
A-one Roblox Square
Hello, here you can on roblox bugs and more.
https://advancedjournals.org/nonsense-diamond-v1-9-roblox/.html
https://advancedjournals.org/delivery-simulator-script/.html
https://advancedjournals.org/bizarre-legacy-script/.html
Строим из газобетона и пеноблоков "под ключ"
Дома из пеноблоков и газоблоков под ключ. Качественное возведение домов, проекты и цены на любой вкус
тел. +7 (962) 982-05-13
<a href=https://stroimdom-dmd.ru>перейти на сайт</a>
Protect APIs
ATO ProtectionBot Mitigation: https://www.metal-archives.com/users/Wallarm
ATO ProtectionBot Mitigation: https://linktr.ee/Wallarm
API Security Testing: https://amara.org/en/profiles/profile/MHpDOukW1AK6T9AoLxaZ8ZL-uLOoc-Mfv…
Protect APIs
API Security Testing: https://artmight.com/user/profile/426803
ATO ProtectionBot Mitigation: https://wallarm.livejournal.com/profile
API Discovery: https://www.engineering.com/profile/Wallarm
Protect APIs
API Security Testing: https://www.metal-archives.com/users/Wallarm
API Security Testing: http://uid.me/wallarm_com
API Security Testing: https://www.funadvice.com/wallarm
Protect Apps
API Threat Prevention: https://www.gamerlaunch.com/community/users/blog/6148647/?mode=view&gid…
API Security Testing: https://www.trustami.com/erfahrung/62232a1f2b5d85d67e8b4568-bewertung
API Discovery: https://www.thingiverse.com/wallarm/designs
Protect APIs
API Discovery: https://runet-id.com/2264791
API Discovery: https://www.imdb.com/user/ur150475660
API Threat Prevention: https://www.weddingbee.com/members/Wallarm
Add new comment