INTRODUCTION TO FUNCTIONS
We will talk about all functions. The function is significant, especially when it comes to making your code not only more readable but more functional. You can make your code do more than one thing at once instead of rewriting a ton of code. Let’s start a new project to see what I mean by that.
data:image/s3,"s3://crabby-images/37b07/37b073c97ac3e8d623a387246a64a8a01d3fe624" alt=""
data:image/s3,"s3://crabby-images/f9395/f939562aceb05031bea004f7d3d23274d24d8d2b" alt=""
We’ll call this ‘Function Test’, and it doesn’t matter what the size it is at this point.
data:image/s3,"s3://crabby-images/c195a/c195a697f6e4f0761d31b66adcdf6a938f474c99" alt=""
data:image/s3,"s3://crabby-images/026c4/026c4ce795e1803fbf989505dd5708024253d53a" alt=""
data:image/s3,"s3://crabby-images/3335b/3335bfde58f237f7e41bce5f2e946fb079a67444" alt=""
data:image/s3,"s3://crabby-images/3de4e/3de4e81521824ce3262a1b106474f1c802cf6214" alt=""
data:image/s3,"s3://crabby-images/4c576/4c5760f929877056d51269bd26e296f609eb0723" alt=""
It’s basic. The first thing we add is a function.
data:image/s3,"s3://crabby-images/cb9e1/cb9e19ce98a5e21993ecebce731c5b701d58f72a" alt=""
data:image/s3,"s3://crabby-images/43af8/43af8b7967492024a4c8f5475e806ef6eaab13e1" alt=""
data:image/s3,"s3://crabby-images/e8fe8/e8fe827467e15304ac76becec8d06da133253db4" alt=""
It allows us to add a function, let’s add a ‘Sprite’ here.
data:image/s3,"s3://crabby-images/fd584/fd5849b6ee297199db432f7b2c53643e8864c540" alt=""
data:image/s3,"s3://crabby-images/ba313/ba313c79ee6d9c137cf80f0536425e59b4aa61f1" alt=""
data:image/s3,"s3://crabby-images/cd9f1/cd9f1175b094b805cd9fb9f6c3afea45ad72191c" alt=""
data:image/s3,"s3://crabby-images/d6a45/d6a454743945e2295573e9c6acee738ce1b28fe6" alt=""
We will create 32 x 32 and black.
data:image/s3,"s3://crabby-images/4e2e3/4e2e3a2cae0c91f027669f4fe115da61b8946b66" alt=""
data:image/s3,"s3://crabby-images/7948d/7948dc69d1dfe2e96d9ec3d31ce43fe745b149e5" alt=""
data:image/s3,"s3://crabby-images/d2eb7/d2eb75da458c907934c6d47549688d3951d7f61e" alt=""
data:image/s3,"s3://crabby-images/68992/68992d50be8d01031f9fb1007f5e8a22c044994a" alt=""
We call this ‘Player’
data:image/s3,"s3://crabby-images/bec7c/bec7c26a1069c0a29b50009911caf54006044c7f" alt=""
data:image/s3,"s3://crabby-images/15632/15632ceb4a5d2add027afa551c7211b607968adf" alt=""
We have this ‘Sprite’ on the screen, and let’s see some functions.
data:image/s3,"s3://crabby-images/7a8f5/7a8f50604cae9c8a4d1b85779af6ba4e9eb81d6d" alt=""
data:image/s3,"s3://crabby-images/ff646/ff6468feeaf79b1f5a62355803477eb7dbec22ca" alt=""
You will have the functions here.
data:image/s3,"s3://crabby-images/e1adc/e1adc5480b38460bb3f81e2357223717cb5c1dd5" alt=""
data:image/s3,"s3://crabby-images/e908a/e908ab18ab0c9f474a2e69a4b99735552fee519f" alt=""
data:image/s3,"s3://crabby-images/9d7df/9d7dfc51e7ded90722eddbe43457c43ec7e080d3" alt=""
You can click ‘Compare parameter’
data:image/s3,"s3://crabby-images/2c883/2c88351262609cbd9d793cbdd7e15e908751936a" alt=""
data:image/s3,"s3://crabby-images/c97e6/c97e6b76dd22e08309f44c8ab5db7c315ae381ae" alt=""
Or you can click ‘On Function’
data:image/s3,"s3://crabby-images/87ff4/87ff42d89072bfd4e7c6ae47c5544e83e0219cd8" alt=""
data:image/s3,"s3://crabby-images/a8d89/a8d89ae9cecf4d6d6497198abd06796fe9ecabec" alt=""
Let’s say you change the opacity. That’s what you name your function and what it will do. If you’ve ever taken a coding course, you probably are aware of functions, and you’re probably wondering why there are no functions in ‘Construct 3’. I mean, is it the essential part of programming? Technically you can do a lot of this stuff in ‘Construct 3’ without the idea of a function, but since functions are ingrained in coding thus, I had to put it in. The name of the function should say what it does. You don’t want a function name like this because it’s not descriptive enough of what you need.
data:image/s3,"s3://crabby-images/ed83d/ed83ded6597f2e75f61d1339b53b17fa512e8bd3" alt=""
Let’s say you set the name to ‘ChangePlayerOpacity’. As you can see, all words are capitalized.
data:image/s3,"s3://crabby-images/d65da/d65da6a9e2063c724c6d90e1c820d73110a891df" alt=""
Some people like to add an underscore.
data:image/s3,"s3://crabby-images/644e8/644e83b689e709c0f6acd9a4bd4a01e3e42ee75c" alt=""
Whatever style works for you, this is the one for me.
data:image/s3,"s3://crabby-images/f154b/f154bf22e16c7dd0f08c4ca34fdca92681afbc8d" alt=""
data:image/s3,"s3://crabby-images/88e85/88e85de62801a80c96893c8cb1fa241a85fc14aa" alt=""
‘On function’ we can change the opacity of the player to 50%
data:image/s3,"s3://crabby-images/14a7c/14a7c2ef437101523072daa83feb0e39fa3018da" alt=""
data:image/s3,"s3://crabby-images/56938/56938b83204a9cb8d01f26e980cf8c66badd2a7d" alt=""
data:image/s3,"s3://crabby-images/5562e/5562e15727f60dddbd8a7362baebcf971a7ebbb9" alt=""
data:image/s3,"s3://crabby-images/aa040/aa0409bb5197751f3d4ad588191ab552c256585d" alt=""
Now at this point, nothing happens. Nothing happens because we haven’t called the function yet. If I go to ‘System’ at ‘On start of layout’, I call the function and that function changes the opacity of the player.
data:image/s3,"s3://crabby-images/42850/42850c12883b811f31079a2f94b313e3257ef01a" alt=""
data:image/s3,"s3://crabby-images/b9481/b9481aa5173914e51e90e796ad54b69b5fb46ccc" alt=""
data:image/s3,"s3://crabby-images/7416b/7416b84383b22eed457e9ab896c4135ec9e91d1c" alt=""
data:image/s3,"s3://crabby-images/7ebd9/7ebd9f8b84223613aec69c29bcaf2b28fcf0d51e" alt=""
data:image/s3,"s3://crabby-images/d8bfe/d8bfe9fdad8bb7925732a8e646022e35e9c3a71c" alt=""
data:image/s3,"s3://crabby-images/0701b/0701bf287f30e69dc050a272acaba57896b5c3df" alt=""
data:image/s3,"s3://crabby-images/74829/74829cd0eb37a2f71b5b904e4a83f08866a9bbfd" alt=""
data:image/s3,"s3://crabby-images/31069/31069ea87125c2710bef2512da46710e2db40b7c" alt=""
Let’s take a look at this here.
data:image/s3,"s3://crabby-images/8da71/8da7184e71de4077d6c31142fd0805ac3c8b9fba" alt=""
data:image/s3,"s3://crabby-images/62f52/62f52ee3fb86c7fafe077d97be9756bfc8f50187" alt=""
data:image/s3,"s3://crabby-images/e5d4b/e5d4b601440c90f48f051a9d34a904abcfb24110" alt=""
data:image/s3,"s3://crabby-images/b4ba1/b4ba13ce9311e06fa350b0b34664a34443d6320f" alt=""
Very easy. If you want to add ‘Keyboard’, you can call this function another way.
data:image/s3,"s3://crabby-images/b34c2/b34c290a5ed561ad53da9c5a053b15ecbfac0f3d" alt=""
data:image/s3,"s3://crabby-images/99f8c/99f8c98f929c17e6717fae06c16cb2f37fe4427b" alt=""
data:image/s3,"s3://crabby-images/7614a/7614a3d41f43aea57e5a0572a9c2b014bccee816" alt=""
data:image/s3,"s3://crabby-images/79cd2/79cd271ee4c13393a31912d4dacf6b5666fcc492" alt=""
I want the keyboard on a key pressed, we click ‘On key pressed’
data:image/s3,"s3://crabby-images/cf6a4/cf6a4353421a715185c687de930d675eb2664050" alt=""
data:image/s3,"s3://crabby-images/8b413/8b413dfa3b043b48f73ffd745b7baed751faadb3" alt=""
data:image/s3,"s3://crabby-images/2d687/2d687998e04a675ded984267dc5b728c4ae1ecdb" alt=""
data:image/s3,"s3://crabby-images/9af45/9af45951f8a89a5858e41bf79314641c8f70c59b" alt=""
data:image/s3,"s3://crabby-images/791ad/791ad368ba0e9eb1c9cb687be43effef99866e84" alt=""
data:image/s3,"s3://crabby-images/da307/da307b50bc887281c90183d347700919f43fae51" alt=""
data:image/s3,"s3://crabby-images/54ba4/54ba4d9ff799638d622b771c428bd4d8203e7bec" alt=""
data:image/s3,"s3://crabby-images/a0c7a/a0c7ad8b266a6c84527e0bdeb6d00b033ba3ac54" alt=""
I will remove it from the ‘On start of layout’ now. If I push the ‘W’ key, you can see that the function gets called.
data:image/s3,"s3://crabby-images/23585/235854c43544b81e68bcf574371edcf902afb414" alt=""
data:image/s3,"s3://crabby-images/21aff/21aff7fb98f58148e0310532ed0a622ebbd505ba" alt=""
data:image/s3,"s3://crabby-images/c03c2/c03c27e61982f775d4dcb077e4a9916a840a8596" alt=""
Therefore, if you need to set the player opacity ten times, you can call this function as many times as you can.
data:image/s3,"s3://crabby-images/253e3/253e362e6fabf133004b3808ec68ce7bd11aebb9" alt=""
One of the best ways to use functions is with controls.
data:image/s3,"s3://crabby-images/7ff84/7ff8489b598ebd6e8c67cb8734e704b7179a2c0b" alt=""
Let’s say we’ll change this to ‘MovePlayerUp’
data:image/s3,"s3://crabby-images/89d8b/89d8b30ab2a04fad207096ad375e35bf46f91033" alt=""
If I want to move the ‘Player’ up, I will add some basic controls such as setting the ‘Player’ moving an angle of 270 and the distance of 32.
data:image/s3,"s3://crabby-images/f3baf/f3baffad07e052a4aa6d54697796dfffdac319a6" alt=""
data:image/s3,"s3://crabby-images/5ced8/5ced8889c03c52e827ae949723ee24cd9cba7d29" alt=""
data:image/s3,"s3://crabby-images/cb6fe/cb6fe318856e244f542a7c546b6cffb7dfde27d9" alt=""
data:image/s3,"s3://crabby-images/d8e91/d8e91fdc59679372979fca09dd7fcca41f9d4987" alt=""
data:image/s3,"s3://crabby-images/ef711/ef711123673b3f247f5d0d612b7f6ea2c02039bc" alt=""
data:image/s3,"s3://crabby-images/83eeb/83eeb9ff9eeb107e7cbfea57dc04a206e49808cd" alt=""
data:image/s3,"s3://crabby-images/67960/6796087e0ead68c1facdeea8385ab00b44a42a5f" alt=""
I press ‘W’, but it doesn’t work anymore because I have to call the correct function ‘MovePlayerUp’
data:image/s3,"s3://crabby-images/27e1d/27e1dc6df658778afbe32c8067b2a6d21c01bd7d" alt=""
data:image/s3,"s3://crabby-images/7e53c/7e53cecf0e551fc0bdb672a10cd55e5e9efc115f" alt=""
data:image/s3,"s3://crabby-images/2d785/2d785683ad9a7c984e6d07d90077384814bc302d" alt=""
Let’s move the ‘Player’
data:image/s3,"s3://crabby-images/8d967/8d9670670daf5d1d37a4075609530a5521b957d4" alt=""
data:image/s3,"s3://crabby-images/82252/82252c75815567f1b8f5c2c39dce7a815bb7ef27" alt=""
data:image/s3,"s3://crabby-images/5f73d/5f73da47922407d73156534b48d7b5989eab045e" alt=""
You see that it moves up.
data:image/s3,"s3://crabby-images/75040/75040c1c22801911587fca422a0fdf9dcbcb780d" alt=""
data:image/s3,"s3://crabby-images/e7fcb/e7fcb0955c0fd3d71546ca57232c4b3b536fcd54" alt=""
You can work with it on any single platform.
data:image/s3,"s3://crabby-images/72a93/72a9363f8cfb129283e3d6de510ab91c1a2eec07" alt=""
Therefore, if you’re working on this on a mobile device like a phone, tablet, laptop, or computer, you can run it. That’s the whole idea. Let’s say you move the ‘Player’ up.
data:image/s3,"s3://crabby-images/c4823/c48233431f4614bf3845a0202610cb39bd6c35de" alt=""
Now, this is one thing you can do. You have a bunch of different things like ‘Set animations’ or you can ‘Set blend mode’ or ‘Set height’
data:image/s3,"s3://crabby-images/47786/477868fc1fe5ed515109dded6302e95becc54593" alt=""
data:image/s3,"s3://crabby-images/ac285/ac2855b90afbd30f4e967cf1bd1c4b61a7daaa97" alt=""
data:image/s3,"s3://crabby-images/5736e/5736ea610f01e206923234922e7c5db8e08aa7df" alt=""
data:image/s3,"s3://crabby-images/cbfcf/cbfcf74e7a4bf9c35856e6b829dbb1e04862b454" alt=""
data:image/s3,"s3://crabby-images/c5a46/c5a4602b2ed821382fe5751e66fd1b805d4778e1" alt=""
data:image/s3,"s3://crabby-images/83147/83147a41e3bdb509f2b195fbd4dff4e283291f15" alt=""
You can set all these different items as you move ‘Player’ up and when creating the game.
data:image/s3,"s3://crabby-images/d4eff/d4eff969f5bb80f9d1402fcb1f6bd89c29d33448" alt=""
Now, we have a ‘Keyboard’. Let’s say you want to add another type of control such as ‘Up Arrow’
data:image/s3,"s3://crabby-images/e869e/e869ea21f4a34ad863fb3ad89fb04125defca839" alt=""
data:image/s3,"s3://crabby-images/f724c/f724c713ef707dadc39edec76acefa3cc5a60841" alt=""
data:image/s3,"s3://crabby-images/897a7/897a77b062a2633c6734e1068aa778dd78a5d54d" alt=""
data:image/s3,"s3://crabby-images/5be5a/5be5a933d666af397e9ef64bda2b8650ab7dbb03" alt=""
data:image/s3,"s3://crabby-images/e7ffb/e7ffbca206710d2954d64fd6b95645486ae9d72c" alt=""
data:image/s3,"s3://crabby-images/f4f88/f4f88016e2e5e37faf571671a2f185903aac7d20" alt=""
data:image/s3,"s3://crabby-images/43a8f/43a8f6b968e2e0f1b34be98a9b929c561d390a9c" alt=""
data:image/s3,"s3://crabby-images/1cd0f/1cd0fd03438b3c68f285549390bf3b3f563f80c0" alt=""
Let’s look at a few things.
data:image/s3,"s3://crabby-images/e4384/e43840cca6c80202ec74c93b2b7a93ab9e5f6e80" alt=""
Let’s add ‘Touch’ and ‘Gamepad’
data:image/s3,"s3://crabby-images/a2c42/a2c42f80b4d8ebfeb076fe86528a420d4fef18a9" alt=""
data:image/s3,"s3://crabby-images/8a56f/8a56f4acad1872c0ce99172839b3539b02ea525c" alt=""
data:image/s3,"s3://crabby-images/df8a5/df8a5435a652d3fe65a1c5694de98513b237bcc9" alt=""
data:image/s3,"s3://crabby-images/f7a7e/f7a7eb52b12e978d75e3d6c0e8e6c3462543d50a" alt=""
data:image/s3,"s3://crabby-images/4e8b2/4e8b2c1e5b95fe021e9a9d20399d60410d3f7b3f" alt=""
data:image/s3,"s3://crabby-images/13f08/13f08a1402f3158480bcbec33970d281de4407bf" alt=""
data:image/s3,"s3://crabby-images/369d4/369d447579a310341de7006a2e0feb5d0d83edbc" alt=""
data:image/s3,"s3://crabby-images/81126/81126aa48070a6a77dc66f228f919e91175a7c6a" alt=""
data:image/s3,"s3://crabby-images/50865/5086521efa9bfcca00b86f6b38787a3b87db4f25" alt=""
data:image/s3,"s3://crabby-images/21b01/21b017fe40cf95da207a32dd25608fb46025c37f" alt=""
data:image/s3,"s3://crabby-images/95684/956841d5518ad4274437403f9b83b01caa54e1a5" alt=""
data:image/s3,"s3://crabby-images/f1317/f1317561a93a9671c91eb83749235ccadf4c5f90" alt=""
data:image/s3,"s3://crabby-images/12137/121375e8886abe310eb61cd3c06a4793b38325c4" alt=""
data:image/s3,"s3://crabby-images/6b0bf/6b0bf200a4c0a41029644ef03ee53fc4a320febc" alt=""
The first value is ‘Player.Y’ which is greater than ‘Touch.Y’. Then we will call the function again.
data:image/s3,"s3://crabby-images/fbbda/fbbda730b487bd108838b8714e0e71827c34061f" alt=""
You just need to copy and paste it here.
data:image/s3,"s3://crabby-images/3461d/3461d0a1868ebd690919e6811cc63af8ecccf7c5" alt=""
data:image/s3,"s3://crabby-images/6e5db/6e5db1e215608101325720ad4aa74dd709ff0368" alt=""
data:image/s3,"s3://crabby-images/c3707/c3707392a3fd2556d83de35bc81a1932ef7ea4de" alt=""
data:image/s3,"s3://crabby-images/0b1cf/0b1cf22bf43664fbaf26a66d47d29aab43f12f48" alt=""
data:image/s3,"s3://crabby-images/9c297/9c297678c79b3b6fb4e96616ca486cbd0a43c89a" alt=""
You must also add another condition. We have three different types of controls here.
data:image/s3,"s3://crabby-images/f0cd7/f0cd760e98c4dde65dfc197e69b754bcda2b6c2e" alt=""
data:image/s3,"s3://crabby-images/270d2/270d2a33a98a9261a9993c290f93c28e1dbd379a" alt=""
data:image/s3,"s3://crabby-images/e7796/e77961519b92d4da9f8a4af3ad3d440c9e19ac76" alt=""
data:image/s3,"s3://crabby-images/83412/8341252108af779ad76e8081cf1c6fa98aeb0ff7" alt=""
data:image/s3,"s3://crabby-images/e6b77/e6b772b77bbcc9e0b270d06ffbd6d655488cd457" alt=""
data:image/s3,"s3://crabby-images/df62e/df62ec4ac9c8e2b67acf2b12b4ceb45ee4e05d20" alt=""
The next thing we can also add in ‘Gamepad’ is ‘Gamepads are supported’ and another condition is ‘On button index pressed’ and ‘On any button pressed’
data:image/s3,"s3://crabby-images/50c64/50c6463da82173cce3f6eccbfb34230b8197901d" alt=""
data:image/s3,"s3://crabby-images/c9dfc/c9dfc34be05537eec3e9515b382ee2fe5152d6e4" alt=""
data:image/s3,"s3://crabby-images/f8d4e/f8d4eb1a3aacd151db32c2a61ad2f6e52578f256" alt=""
data:image/s3,"s3://crabby-images/2b50d/2b50d5a2c377ba0167958ede9a137c199f75940d" alt=""
data:image/s3,"s3://crabby-images/28646/28646d61d184146c3371c680da8feeac61d77932" alt=""
data:image/s3,"s3://crabby-images/98ead/98ead0b3496c972a5409601536bcdaf7cdfef521" alt=""
data:image/s3,"s3://crabby-images/cf090/cf0908a9c03cadd1e7cb424958ffa13f4dc23376" alt=""
data:image/s3,"s3://crabby-images/db015/db015b81170a316cfab77465f0a5d8ccc0feaafc" alt=""
data:image/s3,"s3://crabby-images/391a4/391a4efa616ee89c1bd59b3736295292ebedc882" alt=""
data:image/s3,"s3://crabby-images/dc666/dc666f125568199f654a978c81303810551db1b8" alt=""
data:image/s3,"s3://crabby-images/923f4/923f4d38cca9255186229cc8b48a4a879e4a2014" alt=""
Now, we have ‘MovePlayerUp’ and a function.
data:image/s3,"s3://crabby-images/b55a7/b55a7ac4d9cb3a25c85ea531da6d2d63e02d56f3" alt=""
data:image/s3,"s3://crabby-images/1ce8c/1ce8cc6c6ac5e85f6112146e9c89d00eeed3ede7" alt=""
I want to show you a project I have been working on.
data:image/s3,"s3://crabby-images/48b03/48b0364278bd4826e00791d0b725e7e26345f85f" alt=""
data:image/s3,"s3://crabby-images/ab647/ab647be05d6ef8bb36c66bf1b0ad5514ef247bac" alt=""
data:image/s3,"s3://crabby-images/fedba/fedbad5764b5937e5800a9686a1869aa4ebdf9c7" alt=""
These are all different types of tabs, and I will show you how they work here.
data:image/s3,"s3://crabby-images/0aef0/0aef0b130edf85c88e67f2f7fbf12003a2ee14c4" alt=""
data:image/s3,"s3://crabby-images/1ac82/1ac8241a726605377343a64f8cb6c6d1d1bb9e1a" alt=""
data:image/s3,"s3://crabby-images/5d13d/5d13d2bf39101fdb30b3ba7c37ba74ec6b1aceb7" alt=""
data:image/s3,"s3://crabby-images/c0a25/c0a25e8918273ecbd7eb22dee230a8e720ac776f" alt=""
It is a simple game. Here are all functions left to right and work.
data:image/s3,"s3://crabby-images/bf165/bf16501128eb07a995716898bf2bf64189036e9c" alt=""
data:image/s3,"s3://crabby-images/c1f47/c1f474e79190ddeffe192464ed408837853ed81c" alt=""
data:image/s3,"s3://crabby-images/845b9/845b96420117fc52680f20380b88317b5e6865de" alt=""
data:image/s3,"s3://crabby-images/d2b4b/d2b4b616ebd4c4371f6accae30f7b719c59c6ea1" alt=""
I have ‘Gamepad’ controls and ‘Platform’ controls.
data:image/s3,"s3://crabby-images/63de2/63de2de514ff8ad2ff8e85265ce7f4fd64b8dc3e" alt=""
data:image/s3,"s3://crabby-images/4f850/4f8500bc85b23a404385cc093a22f8066927de2a" alt=""
data:image/s3,"s3://crabby-images/d9f96/d9f96fc0367d34c7b2a83a5136ad5d7fae291764" alt=""
data:image/s3,"s3://crabby-images/c83f5/c83f5c4df94d347df11dc4577edb9a70d5793d33" alt=""
data:image/s3,"s3://crabby-images/e1702/e1702210af549a478296c067349a7cb123adabfe" alt=""
data:image/s3,"s3://crabby-images/d4d4b/d4d4b76407751b33c39ddcafaea9772732798155" alt=""
This game I am showing you is easy. Therefore keep in mind that the more complex your game becomes, the more functions you will have to add.