For the Week 9 assignment, we were supposed to get information from at least one analog sensor and at least one switch, and use this information to control at least two LEDs, one in an analog fashion and one in a digital fashion, in a creative way.
I’ll be very honest, I started the assignment on Saturday but I wasn’t very comfortable with working with the circuit. I knew I could experiment with the coding part, but the fear of damaging any equipment meant that trial-and-error wasn’t the best choice when it came to setting up the circuit. But after going through some websites and class examples and after the Monday class (29th March), I became a lot more confident about setting up my circuit.
I tried to create a traffic signal using Arduino. I set up my circuit with 3 LEDs, corresponding to the red, yellow and green lights, one switch (digital sensor) and one potentiometer (analog sensor).
The red LED can be turned on and off using the switch. It is controlled digitally and its brightness can only be set as HIGH or LOW. When it is on, the potentiometer can then be used to take input and the input generated can be used to make the traffic signal work. The input generated can be mapped onto a variable called mappedValue, which only stores values between 0 to 255 (just like in the class examples).
When the value of ‘mappedValue’ crosses 100, the red light is turned off and the yellow LED is turned on. This yellow LED is controlled in an analog fashion and its brightness is equal to the mappedValue at all instances.
When the value of mappedValue crosses 150, the yellow LED is turned off and the green LED is turned on. The green LED is controlled digitally and its brightness can once again only be set as HIGH or LOW. The green LED stays on as long as mappedValue takes values between 150 and 255.
The entire process can then be repeated in the reverse order, starting from the green LED and finishing at the red LED, which can once again be turned on and off using the switch/button.
A video of the working circuit is attached below.
The code:
int buttonPin = 2;
int ledPin = 3;
int led2Pin = 9;
int led3Pin = 11;
int knobPin = A0;
int ledState = LOW;
int prevButtonState = LOW;
void setup() {
// set pin modes for the 3 LEDs and the button
pinMode(ledPin, OUTPUT);
pinMode(led2Pin, OUTPUT);
pinMode(led3Pin, OUTPUT);
pinMode(buttonPin, INPUT);
// needed in order to start serial communication
Serial.begin(9600);
}
void loop() {
// check to see what state our button is in, and store that information
int currentButtonState = digitalRead(buttonPin);
// if the button is currently being prssed down, AND during the last frame is wasn't pressed down
if (currentButtonState == HIGH && prevButtonState == LOW) {
// flip the LED state
if (ledState == HIGH){
ledState = LOW;
} else if (ledState == LOW){
ledState = HIGH;
}
}
// set our LED to turn on and off according to our variable that we flip above
// digitalWrite(ledPin, ledState);
//we need to remember the state of our button for the next time through LOOP
prevButtonState = currentButtonState;
// reading the input generated by the potentiometer and then mapping it to a variable called 'mappedValue'
int knobValue = analogRead(knobPin);
int mappedValue = map(knobValue, 0, 1023, 0, 255);
// if (mappedValue >= 120 && ledState == LOW){
// digitalWrite(ledPin, LOW);
// analogWrite(led2Pin, 0);
// digitalWrite(led3Pin, HIGH);
// }
// else if (mappedValue < 120 && ledState == LOW){
// digitalWrite(ledPin, LOW);
// analogWrite(led2Pin, mappedValue);
// digitalWrite(led3Pin, LOW);
// }
// else if (mappedValue >= 120 && ledState == HIGH){
// digitalWrite(ledPin, HIGH);
// analogWrite(led2Pin, 0);
// digitalWrite(led3Pin, LOW);
// }
// else if (mappedValue < 120 && ledState == HIGH){
// digitalWrite(ledPin, HIGH);
// analogWrite(led2Pin, mappedValue);
// digitalWrite(led3Pin, LOW);
// }
// setting conditions for turning the 3 different LEDs on and off based on the input generated by the potentiometer
if (mappedValue < 100 && ledState == HIGH){
digitalWrite(ledPin, HIGH);
analogWrite(led2Pin, 0);
digitalWrite(led3Pin, 0);
}
if (mappedValue >= 100 && mappedValue <= 150 && ledState == HIGH){
digitalWrite(ledPin, LOW);
analogWrite(led2Pin, mappedValue);
digitalWrite(led3Pin, LOW);
}
if (mappedValue > 150 && ledState == HIGH){
digitalWrite(ledPin, LOW);
analogWrite(led2Pin, 0);
digitalWrite(led3Pin, HIGH);
}
if (mappedValue >= 0 && mappedValue <= 5 && ledState == LOW){
digitalWrite(ledPin, LOW);
}
}
For this assignment, I have to admit, I did the bare minimum which is fulfilling the criteria for this week. I wanted to control the brightness of one LED to fulfill the analog criteria. Then, to cross the digital sensor requirement, I used a button to control when the LED turns on.
DIFFICULTIES:
The moment I read the assignment prompt, I knew I had to learn the structure of an Arduino UNO board since I forgot everything we took in class lol. However, that was fruitful since I learned some things about Arduino boards we did not cover in class 🙂 I also faced difficulties with matching the name of the parts like the potentiometer to the pieces we have in our kits since there are different designs of the same pieces.
IMPLEMENTATION:
implementing the pieces and writing the code was fairly easy after learning the structure of the Arduino UNO board. I used a blue LED to be controlled by the potentiometer since it’s blue as well, additionally, I used a red LED to be used with the red button to make it more easy/satisfying to use.
CODE:
const int analogIn = A0;
const int analogOut = 5;
const int buttonPin = 4;
const int ledPin = 7;
int sensorValue = 0;
int output = 0;
int buttonState = 0;
void setup() {
// initialize serial communications
Serial.begin(9600);
pinMode(ledPin, OUTPUT);
pinMode(buttonPin, INPUT);
}
void loop() {
// read the analong input value
sensorValue = analogRead(analogIn);
// map it to the range of 0 to 255
output = map(sensorValue, 0, 1023, 0, 255);
// change the analog out value
analogWrite(analogOut, output);
// delay 2 milliseconds
delay(2);
// read the state of the pushbutton
buttonState = digitalRead(buttonPin);
// check if the pushbutton is pressed
if (buttonState == HIGH) {
// turn LED on:
digitalWrite(ledPin, HIGH);
} else {
// turn LED off:
digitalWrite(ledPin, LOW);
}
}
// higher number is slower
int speed = 20;
// change spread to make the bell curve wiser or narrower
float spread = 0.12;
// set the postion to start outside of 0 to 1 so the first LED is dark
float bellCurveCenter = -spread;
float ledPos[3] = {.25, .5, .75};
int ledIndex[3] = {5, 10, 11};
void setup()
{
for (int i=0; i<3; i++){
pinMode(ledIndex[i], OUTPUT);
}
}
void loop()
{
// this is the juicy part
for (int i=0; i< 3; i++) {
// finding the distance of each LED from the center of our bell curve
float distance = abs(ledPos[i]-bellCurveCenter);
// this is the formula for the bell curve, multiply by 255 to put in the proper range for brightness
float brightness = exp(-0.5*pow(distance/spread, 2.))*255;
analogWrite(ledIndex[i],brightness);
}
// move the center
// you could adjust the speed with a potentiometer
if (millis()%speed==0)
bellCurveCenter += .01;
// start it over when it reaches the end
// reset based on the spread so that it fades all the way out before resetting
if (bellCurveCenter>1+spread) {
bellCurveCenter = -spread;
}
}
const int ledPin = 6;
long timer = 0;
int timerLength = 500;
bool onOff = false;
void setup() {
// put your setup code here, to run once:
pinMode(ledPin, OUTPUT);
}
void loop() {
// put your main code here, to run repeatedly:
if (millis()>timer){
onOff = !onOff;
digitalWrite(ledPin, onOff);
timer = millis() + timerLength;
}
}
I really wanted to use the Network library in Processing as this was something new to me. Thus, I hoped to create some sort of two player game.
As a kid, my siblings and I would make a grid of dots on napkins and play the dots and boxes game where you’d have to form as many boxes as possible by drawing lines between the dots.
I hoped to implement a version of this game with a limitation of what dots you could draw on.
I began by creating the Dot class. I thought about user feedback a lot for this object. When the user hovered over a dot, I wanted it to become lighter. I wanted there to be a beep tone. Upon selection, the dot’s color would change. I originally just kept the posX and posY of each dot object, but later realized it would be useful to be able to have the row and column number as attributes to avoid multiple for loops.
Working with the server and client was easier than I expected because it was quite simple to send data over the socket. Originally, I sent a longer string, also including variables like whether a box was created, etc. I realized this was redundant and I would just need to send the selected row and column dot numbers and have a function to handle the data on each side and see whether a box was created, etc.
Some of the edge cases I identified for error validation:
Does the user select exactly two dots?
Does the user select “opponent dots?”
Does the user select dots that are next to each other (not including diagonals)?
To keep track of the dots selected before they were sent to the other player, I used an ArrayList to hold the dots. When the user clicked the user button, the error validation process would occur. If it was okay, then the data was actually sent.
The most difficult aspect for me was designing how to track boxes. I first created another ArrayList to hold all the pairs of a dot, but that was quite inefficient. I also tried manually checking each potential box position, but that was also unsuccessful. I ended up creating a Box class that matched row and column numbers with the dots. This worked because I could simply refer to the x and y position attributes in the dot class when drawing elements like lines between dots and rectangles for the boxes.
Another challenge was making sure to avoid having an array out of bounds error when checking dots/boxes on the edge of the grid. I solved this by only checking a dot if it was within the boundaries of the grid.
Finally, I did not redraw the background each time. Redrawing the background would remove the lines and boxes. Perhaps, I could have redesigned my architecture to draw lines and boxes each frame depending on certain attributes of the objects. However, my choice to not redraw made things difficult when updating the error message and scores. I ended up cheating a bit and redrawing a rectangle on top of the old messages with the same color as the background.
I relied on the Processing function mouseMoved() to help detect hover state of the dots and make the color slightly lighter. I used mouseReleased to help click the dots and do error validation.
I created a start screen to fulfill the image requirement of the project. I designed the screen image in Figma. When the user clicks, the game state changes.
The end screen comes up when every box has been completed.
Overall, this project was fun to complete and I became a lot more familiar with the Network library.
As always, there is room for improvement. I would make the project better by:
having a grid size option so the user could make more or less squares depending on their preference
having background music in the beginning
having an option to mute sound
having an instructions/pause game state
having a more beautiful method of filling in the rectangles
changing the “end turn” button if it is not the user’s turn.
use ngrok to make it more playable
But, I suppose there is always more one can do so here is my game for now. The game takes around 12-20 minutes to play through, so here is my game in about a minute. The audio is quite messed up in the demo video since I am playing it at 20x speed.
For my midterm project, I decided to do something related to sports because I was really amused by the kinetic physics models that Professor Aaron had showed us in class. And so building on top of that, I made a simple 2d basketball game wherein the player can control the force applied on the ball and the direction of its trajectory, with the goal being to score at least 15 points in a given time frame. The time frame can be decided by the user and offers them three levels: beginner wherein the ticker is quite slow, intermediate, ticker is pacy but still doable and advanced, it would be a genuine achievement if you can win this level.
Here is the video for my game:
Here is my Git for this project:
https://github.com/Armaan-Agrawal/IntrotoIM.git
For this project, I really wanted to focus on a 90s video cassette type feel to it and so I curated the animations keeping that in mind. I purposely made th audio and timer controls slow so as to accentuate the feel of that old era gaming.
For the audio slider, I basically implemented it using maps
For the animation, I did it through assigning variables to manioulate location and direction.
For the bounce in the ball, I achieved it by dampening the velocity of the ball upon collision.
The physics of the ball is based on the Newtonian laws of motion.
I found most of the game art online but had to curate certain pieces like the baskeball and the player through photoshop to get the desired effect.
So, after the weird phase of having two separate codes that did two separate things (for those weird ones reading this post of mine for some unknown reason, that post is private because I am so ashamed of my level that you shall never see it or else I am going to die from embarrassment) I moved on more risky stuff (at least in my opinion) (and if this is Professor Aaron reading this code and seeing that it’s private, it means that halfway though I got very self-conscious about my code and decided to privatize it).
So, what I did was “merging” them in a way. I needed to substitute ellipses for the images of the books and Instagram. On the way there I changed the pictures because I didn’t like the way the designs of the ones I had looked next to each other, especially now that the background changes from black to white.
In order to change the images, I went to the Dropclass and changed the ellipse shape to (image) and there I added all the required global variables and yay, it worked 😀
class Drop {
float x;
float y;
float r;
float speedY;
float c;
PImage dropbrain;
boolean isCaught;
Drop() {
r = 8;
x = random(width);
y = -r*4;
speedY = random(1, 50);
isCaught = false;
}
void update() {
//position
y += speedY;
//check bounds
if (y>height + r) {
y = -r;
}
}
void display() {
if (isCaught != true) {
imageMode(CENTER);
dropbrain = loadImage("dropbrain.png");
image(dropbrain, x, y, r*4, r*4);
}
}
void caught() {
isCaught = true;
}
void reset() {
}
}
//If (drops[I].alive==true){drops[I].show; drops[I].move}
Then, a few interesting things happened, because I needed to add another drop class for the “bad” things that were going to serve as a distraction (aka instagram). I figured that I needed to create another class, and it would be exactly similar to the dropclass I already have. So, I create badDropclass and copied the information from the class above with few alterations of changing the image and adding changes in names of for() loops in the main CatcherGametab.
The tricky part gets when the images did not disappear when intersecting with the little brain image of a catcher. I asked Mister Jack about this, and he showed a pretty handy solution.
My main issue is that despite having drops[i].caught in the main sketch, I didn’t put the code in there, so it wasn’t running any functions. I needed a boolean that would indicate whether the drop is caught or not. So, after adding it, it worked, yay!
So, now that I had a game that was running with everything except without a score that went down when you caught badDrops. I needed to solve that. So, I just added thescore-- in the for() loop for badDrop in the main sketch.
if (intersect(catcher, badDrops[i]) == true) {
badDrops[i].caught();
score--;
}
That worked, however, now the score went to a negative number and I needed the player to lose when the score was less than a zero. Finally… Time for an iffunction has come. You may not believe it, but I actually never used it because for some unknown reason I was very scared of the power it had. It is partially the reason why I choose switch screen function instead of multiple iffunctions. I have been avoiding it for as long as I could. So, when I used it today it was a pretty big deal. And of course, I failed :,)
The function worked, however, the reset part of the score did not work, so the game did not switch back to screen 0 (or instructions page) since the scoredid not reset back to zero. So it basically prevented me from changing the screen by pressing the key. I sat there watching the screen and changing the placement for a good 3 hours and after almost giving up and thinking about dropping Interactive media I decided to ask help from, you guessed it, Mister Jack. Mister Jack enlightened me in the simple truth that my screen was reset, but my small brain should’ve focused on void keyPressed() instead of changing the placement of the iffunction. So, after changing the placement of score = o to void keyPressed(), my game worked, and now I am here :3
– I love seeing the suggestions of videos everyone has since mine are always Minecraft related, and it’s accurate, so we actually get a sneak peek of what every one of us watches haha
Conclusions:
Mister Jack is great! If Mister Jack ever reads this, the biggest, huge, enormous thanks to you. You literally saved many (and I don’t have many of them) nerves of mine 😀
P.s. Mister Aaron is great as a given 😀 😀
Private button her is just as great in helping me not die from embarrassment in front of many people. Instead, I just need to feel ashamed in from of Mister Aaron, and I am getting quite used to it. Triple 😀 😀 😀
References:
The YouTube tutorial for the catcher explanation: https://www.youtube.com/watch?v=dti_mVscdxY and https://www.youtube.com/watch?v=gXPf_R_hDP0
The YouTube tutorial for changing the game states that never actually became useful: https://www.youtube.com/watch?v=vgKQHocitd4
This project consisted of creating a game for our midterm assignment. The game had to include several elements such as shapes, images, sound, text, an initial screen with instructions, and a way to restart the game when the game is lost or won.
Process:
Idea:
I had several ideas when I first started thinking about this assignment. One of my initial ideas was to work on the game I had been working on before in Week 3. The game consisted of a car trying to avoid obstacles by using the left and right arrow keys. However, I wanted to challenge myself and create a game from scratch. First, I thought about recreating an old retro game. Then I changed my mind to create a “Whack a Mole” game. Finally, I remembered a game I used to play when I was a child. This game was a mini-game from Mario Bros on the Nintendo called “Sort or Splode”. The game consisted of sorting different colored bombs into their own color platforms. If a bomb was not sorted on time it would explode and the game would be over. If a bomb was placed on the wrong platform, the game woul
d also be over. Since I was recreating a game, I decided to include the creativity part in the visual part of the game. I decided to create my own background and characters and base them on an NYU theme. The idea was to sort falcons and bobcats into different platforms that represent NYU and NYUAD.
Initial Process:
Initially, I worked on creating a bomb class with its appropriate methods and attributes. Next, I focused on creating a game class with its methods and attributes. I also created a platform class but later realized that I did not need it.
I first worked with simple shapes (circles) to see the movement of the bombs for my game. I had to create the release of the bombs first and create movement in them while making sure they do not pass the limits of the screen. After accomplishing the change of velocity direction whenever the circle touches a wall on the screen. Then I focused on adding platforms and making sure circles were also colliding and changing direction with the walls of the platform. Later, I focused on creating an array of bombs and creating instances of the class using the frameCount.
After accomplishing the basic structure of the game, I focused on making different types of bombs and confirming they were placed on the correct platform. Later, I focused on identifying a game loss and finally speeding up the release of the bombs.
The final process was making the initial screen and creating a way to start the game or see the instructions of the game.
Using vectors:
When I first started working on the project, I started using individual variables for the velocity and position in the x and y-axis. However, after researching how to make objects collide, I became aware of the existence of a data type called PVector. After looking through the reference guide in Processing, I decided that using PVectors was much simpler than using different variables. Later, I got a better understanding in class when we worked on physics and coding.
Designing part:
I decided to create my own designs for the background, initial screen, and characters. I first worked on creating the background. I decided to make the background look similar to the original game but with a different theme. The platform design was also inspired by the original platform design in the original game. For the characters, I first started by drawing a circle because I needed the characters to be based on a circle as I initially coded the game to recognize characters as circles. The characters, in this case, had a radius, and therefore designing them as circles were crucial to making the game work. The process of design was difficult because I had to create each element from scratch. For the characters, I only used real images for reference and the rest was completely designed by me.
Challenges:
There were several challenges I encountered while creating this game. Some of the major ones were:
Detecting the walls of the platform:
When I first started coding the collisions of the bombs and the platform, a part of the bomb was passing through the platform. I had difficulties in fixing this because every time I tried a different solution something wrong came up. For example, sometimes the bomb range was not covering all the space available, sometimes the bombs entered the platform and the game was ended, sometimes the change in direction of the bombs was not working. After several trials, I managed to fix this problem by looking through the code and figuring out what was wrong with the dimensions.
Detecting collisions between bombs:
When I first designed this game, I wanted to make collisions between the bombs so that when the player grabs a bomb, the mouse does not accidentally grab two objects at the same time. After some research in physics and collisions, I gave up on understanding this concept to implement so I decided to revert the velocity direction if a collision was detected. This was working fine at the beginning of the game but I realized problems when there were several instances of the bomb within the screen. Later, I changed the code of the game so that objects could overlap but the mouse could only grab one object at a time. This was the best solution I had approached.
Design
The design process was more difficult than I first thought it would be. Creating the characters and calculating the spaces for the background was a challenge. I had to spend more time than I anticipated because sometimes the location of certain objects in backgrounds would not match with the code. There were also certain objects I created but did not use because I did not end up liking the background with such objects.
Conclusion:
I personally really enjoyed the creation of this game and I want to continue making it a better game. I spent a good amount of time making the code work and designing the visual part. At first, I thought it was a simple game to make but it actually ended up being more complicated than I thought it would be. The interaction of the game came out exactly as I wanted and I was satisfied with the visual part of the game. Still, there are certain parts that I would like to change in the future. First, the ending screens for the win and lose of the game are not visually appealing as I did not have the time to create a background for each. I also want to create a level system for the game in the future to make it more challenging. The game indicates a win after 90 bombs are sorted. Finally, one thing I would definitely implement is the part where a function calculates the time the bomb has not been sorted. Although there is a function that identifies if a bomb has not been sorted for a long time and ends the game, I would like to add something to have the player identify unsorted bombs such as making bombs blink or change color or size. Still, I think I am proud of the outcome of this project and I look forward to creating more game projects in the future.
import processing.sound.*;
SoundFile sound;
int mode = 0; //Determines the mode of the background;
Game game;
Platform platform1, platform2;
boolean locked = false;
int score;
Screen screen;
void setup(){
sound = new SoundFile(this, "soundfile.mp3");
size(900, 600);
frameRate(60);
game = new Game();
sound.loop(); //SOUND REQUIREMENT
}
void draw(){
background(130);
game.drawGame();
}
void mouseReleased(){
game.checkrelease();
}
For the midterm project, I did a platform game named. The complete code and all resources can be found here.
This game is for 2 players. The goal is to go through “trials”, collect crystals, and get to the airplane to fly away as soon as possible. There is a small problem – you only have 60 seconds.
I wanted to try to create a game myself, similar to the one I played as a child. I always liked the opportunity to play with a friend at the same time, so I decided to add this opportunity to my game.
For this game, I created several classes: 2 character classes, a platform class, a platform class that cannot be stepped on aka platform enemies, a timer class, an airplane class, and a crystal class. Use the A, W, D keys to move Player 2 and the arrow keys to move Player 1.
Problems:
1. It was not easy to create interaction between the character and the rest of the classes – for the game to be interactive, the player must see everything that his actions in the game lead to. I spent a lot of time trying to figure out what kind of response should follow from the game to various interactions, whether this is a “game over” window or, on the contrary, congratulations on winning.
2. It took time to figure out what the distance will be between the objects at the moment of collision and from which side. It was even harder to understand when the picture of the character was in relation to the center, not the edge.
3. For the crystal to disappear when the character touches it, I had to try several options and go through dozens of “null pointer exception” errors. I am pleased with the result, where the crystals are neatly collected in the corner of the screen.
4. Having two players in parallel is not easy: it was necessary to understand the key pressed and released functions, and also not to get confused with them later. Because I named some variables the same for different classes, the character of the second player did not want to appear for a long time.
Final thoughts:
There is no limit to perfection, and you can modify the game indefinitely. I already have dozens of ideas on how I will improve this game in the future, from a progress bar to numerous levels. However, I am happy with how this game has turned out for me at the moment.
While writing the code for this assignment, I have used all the knowledge gained from the last 6 weeks and I have a certain sense of satisfaction with the result. Also, coding is very time-consuming, and it’s best to start as early as possible.
This game, inspired by the successful Harry Potter book series and the retro game PacMan, consists of discovering the exit of a labyrinth. During their journey, the player will have to overcome the dim light that illuminates their way, which becomes small each time the villainous dementors approach. The player will have to dodge this evil creatures if wants to reach the end of the maze and win the game
The development of the project of this video game was a process that went through a long path of challenges, difficulties and many hours( and entire days of work). Solving some of those setbacks led me to spend hours and hours watching tutorials, consulting with my teacher, others students and some tours of the buildings in search of answers and solutions that in the end were compensated by the satisfaction of seeing the finished product
Sneak Pic
(My laptop can’t record audio, but all the screens are accompanied by music from the Harry Potter series in the actual game.)
Thought Process:
Testing things:
I had a lot of issues testing things in my code, primarily because I have a lot of files, and eventually Processing ran out of memory so I had to delete some stuff in order for the program to run. Testing some functions could take up to 2 minutes to load. I am happy with how the project looks but not that much with its efficiency.
Testing copies of PGraphics
Testing Mask function
Testing the Flicker of the player’s field of view
Testing of the dementors (enemies)
First version of the Instructions
Final Version of the Instructions
Note: I drew all the UI, titles and Sprites for this project
Things I would Improve
I really want to add levels (hard mode, normal mode, easy mode, etc).
I also want to have different sets of enemies and maybe a final boss (Voldermort?).
I hope you guys enjoy this game. I put a lot of effort in it and am really happy to share it with you.