Javaspel programmering handledning - Flappy fågeln Redux (8 / 12 steg)

Steg 8: Konkretiserade spelet: II

Nu är det dags att skapa rörliga bakgrunden som vi ser på välkomstskärmen. Detta kräver att lägga till metoden gameScreen TopClass som flera setter-metoder i PlayGameScreen.

Vi börja med att diskutera tillägg av metoden gameScreen i TopClass - det är där spelet klockan finns. Först skapa två instanser av BottomPipe och TopPipe. Så snart en uppsättning rören går ut på skärmen, kommer de positioneras så att de kommer tillbaka på skärmen. Du kan ange pipe bredden och höjden variabler till vad du vill, men jag utifrån dem skärmstorleken för att optimera spelet för olika skärmstorlekar.

XLoc1, xLoc2, yLoc1 och yLoc2 variabler referera koordinaterna av de två BottomPipe; TopPipe objektens platser kommer att vara i förhållande till de BottomPipe platserna. Jag skapade en helper metod som kallas bottomPipeLoc() som genererar ett slumpmässigt heltal som ska användas för BottomPipe y-koordinaten. Detta nummer måste tillåta både TopPipe och BottomPipe objekten tillåts vara kvar på skärmen.

På nästa rad i koden skapar vi en variabel av typen länge för att hålla aktuell tid för systemet - det ger oss ett värde för den tiden spelet klockan startar. Denna variabel uppdateras i slutet av varje iteration av spelet klockan i om-uttrycket att lagra följande starttider för varje spelklocka iteration. Principen om spelet klockan är att hålla iterera genom while loop tills skillnaden mellan aktuell tid för systemet och iterationen starttid är större än ett förutbestämt värde (i millisekunder). Spelet klockan kommer att hålla iteration så länge loopVar är sant; Detta kommer endast att ändras till false när någon form av kollision upptäcks.

Spelklocka koden innehåller kommentarer för att förklara vad som händer där. Ordningen är: uppdatera element platser, då tolka de uppdaterade delarna till klassen som drar dem, och slutligen faktiskt uppdatera på panelen för att se ändringarna.

import java.awt.Dimension;
import java.awt.Font;
import java.awt.Image;
import java.awt.Color;
import java.awt.LayoutManager;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.*;

allmän klass TopClass implementerar ActionListener {
globala konstant variabler
privata statisk sista int skärmbredd = (int) Toolkit.getDefaultToolkit().getScreenSize().getWidth();
privata statisk sista int SCREEN_HEIGHT = (int) Toolkit.getDefaultToolkit().getScreenSize().getHeight();
privata statisk sista int PIPE_GAP = SCREEN_HEIGHT/5; avståndet i bildpunkter mellan rören
privata statisk sista int PIPE_WIDTH = skärmbredd/8, PIPE_HEIGHT = 4 * PIPE_WIDTH;
privata statisk sista int UPDATE_DIFFERENCE = 25; tid i ms mellan uppdateringar
privata statisk sista int X_MOVEMENT_DIFFERENCE = 5; distansera det rör flytten varje uppdatering
privata statisk sista int SCREEN_DELAY = 300; behövs på grund av långa laddningstider tvingar rör dyka upp halva skärmen

globala variabler
privata boolean loopVar = sant; falskt -> Kör inte slinga; -True > springa slinga för rör

globala swing objekt
privat JFrame f = nya JFrame ("Flappy fågeln Redux");
privat JButton startGame;
privat JPanel topPanel; förklarat globalt att rymma måla verksamheten och möjliggöra removeAll(), etc.

andra globala objekt
privata statisk TopClass tc = nya TopClass();
privata statisk PlayGameScreen pgs; panel som har rörliga bakgrunden i början av spelet

/**
* Standardkonstruktör
*/
offentliga TopClass() {

}

/**
* Huvudsakliga körbara metoden anropas när du kör hittar.jar-filen
* args
*/
offentliga statisk void main (String [] args) {
bygga GUI på en ny tråd

javax.swing.SwingUtilities.invokeLater (nya Runnable() {
public void run() {
tc.buildFrame();

skapa en ny tråd för att hålla det grafiska Gränssnittet lyhörd medan spelet körs
Gänga t = nya Thread() {
public void run() {
tc.gameScreen(true);
}
};
t.start();
}
});
}

/**
-Metoden att bygga JFrame och lägga till programmet innehåll
*/
privata void buildFrame() {
Bildikon = Toolkit.getDefaultToolkit().getImage(this.getClass().getResource("resources/blue_bird.png"));
f.setContentPane(createContentPane());
f.setResizable(true);
f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
f.setAlwaysOnTop(false);
f.setVisible(true);
f.setMinimumSize (ny Dimension (skärmbredd * 1/4, SCREEN_HEIGHT * 1/4));
f.setExtendedState(JFrame.MAXIMIZED_BOTH);
f.setIconImage(icon);
f.addKeyListener(this);
}

privat JPanel createContentPane() {
topPanel = nya JPanel(); översta JPanel i layout hierarki
topPanel.setBackground(Color.BLACK);
Tillåt oss till lagret panelerna
LayoutManager overlay = nya OverlayLayout(topPanel);
topPanel.setLayout(overlay);

Starta spelet JButton
startGame = ny JButton ("börja spela!");
startGame.setBackground(Color.BLUE);
startGame.setForeground(Color.WHITE);
startGame.setFocusable(false); snarare än bara setFocusabled(false)
startGame.setFont (nya typsnitt ("kaliber", Font.BOLD, 42));
startGame.setAlignmentX(0.5f); Centrera vågrätt på skärmen
startGame.setAlignmentY(0.5f); Centrera lodrätt på skärmen
startGame.addActionListener(this);
topPanel.add(startGame);

måste lägga till sist för att säkerställa knappens synlighet
PGS = nya PlayGameScreen (skärmbredd, SCREEN_HEIGHT, true); sant -> vi vill pgs vara startbilden
topPanel.add(pgs);

returnera topPanel;
}

/**
* Genomförandet för åtgärder händelser
*/
public void actionPerformed (ActionEvent e) {
IF(e.GetSource() == startGame) {
göra något
}
}

/**
* Metod som utför plaska skärm grafik rörelser
*/
privata void gameScreen (boolean isSplash) {
BottomPipe bp1 = ny BottomPipe (PIPE_WIDTH, PIPE_HEIGHT);
BottomPipe bp2 = ny BottomPipe (PIPE_WIDTH, PIPE_HEIGHT);
TopPipe tp1 = ny TopPipe (PIPE_WIDTH, PIPE_HEIGHT);
TopPipe tp2 = ny TopPipe (PIPE_WIDTH, PIPE_HEIGHT);

variabler att spåra x och y bild platser för nedre röret
int xLoc1 = skärmbredd + SCREEN_DELAY, xLoc2 = (int) ((dubbel) 3.0/2.0*SCREEN_WIDTH+PIPE_WIDTH/2.0)+SCREEN_DELAY;
int yLoc1 = bottomPipeLoc(), yLoc2 = bottomPipeLoc();

variabel att hålla slingan starttid
långa startTime = System.currentTimeMillis();

While(loopVar) {
IF((system.currentTimeMillis() - startTime) > UPDATE_DIFFERENCE) {
Kontrollera om en uppsättning rör har skärmen
om så är fallet, Återställ rörets X läge och tilldela en ny Y plats
om (xLoc1 < (0-PIPE_WIDTH)) {
xLoc1 = skärmbredd;
yLoc1 = bottomPipeLoc();
}
annars om (xLoc2 < (0-PIPE_WIDTH)) {
xLoc2 = skärmbredd;
yLoc2 = bottomPipeLoc();
}

minska på röret platser med förutbestämda belopp
xLoc1-= X_MOVEMENT_DIFFERENCE;
xLoc2-= X_MOVEMENT_DIFFERENCE;

uppdatera BottomPipe och TopPipe platserna
BP1.setX(xLoc1);
BP1.setY(yLoc1);
bp2.setX(xLoc2);
bp2.setY(yLoc2);
TP1.setX(xLoc1);
TP1.setY(yLoc1-PIPE_GAP-PIPE_HEIGHT); säkerställa tp1 på rätt plats
TP2.setX(xLoc2);
TP2.setY(yLoc2-PIPE_GAP-PIPE_HEIGHT); säkerställa tp2 på rätt plats

som de BottomPipe och TopPipe lokala variablerna i PlayGameScreen genom att analysera de lokala variablerna
pgs.setBottomPipe (bp1, bp2);
pgs.setTopPipe (tp1, tp2);

uppdatera pgs's JPanel
topPanel.revalidate();
topPanel.repaint();

uppdatera variabeln tid-spårning efter alla som har slutförts
startTime = System.currentTimeMillis();
}
}
}

/**
* Beräknar ett slumpmässigt heltal för botten rörets placering
* int
*/
privata int bottomPipeLoc() {
int temp = 0;
iterera tills temp är ett värde som gör att båda rören vara på skärmen
medan (temp < = PIPE_GAP + 50 || temp > = SCREEN_HEIGHT-PIPE_GAP) {
Temp = (int) ((dubbel) Math.random()*((double)SCREEN_HEIGHT));
}
returnera härda;
}
}

Nedan ser du den uppdaterade PlayGameScreen klass som återspeglar tillägg av set-metoderna används ovan. Vi kommer att lägga till lite kod för att konkretisera metoden paintComponent. Först vi sekventiellt Ange grafik färg och skapa rektangeln för himlen och marken och sedan dra den svarta linjen mellan dem. Därefter drar vi posterna i BottomPipe och TopPipe. Dessa element får inte vara null (dvs. de måste ha skapats) för att dra dem.

Efter detta vill vi uppmärksamma "Flappy fågeln" med stora bokstäver längst upp på skärmen. Först inrättat vi ett try-catch-sats att ange teckensnittet. Det första teckensnittet finns inte på datorer, och om inte, vi avancera till programsatsen catch där teckensnittet blir inställd på ett mer universellt teckensnitt. Vi vill också se till att meddelandet är centrerad på skärmen, så att vi får bredden på det meddelande som vi kommer att dra med hjälp av den FontMetrics linjen. Slutligen drar vi meddelandet på skärmen efter try-catch-block.

Nästa förändring gjorde var tillägget av några enkla setter-metoder. Dessa bör vara självförklarande. Den sista ändringen är tillägg av metoden sendText. Vi kommer att använda detta när spelet slutar skicka "Game Over" dras. Denna text kommer att ersätta den befintliga meddelande variabel text.

import javax.swing.*;
import java.awt.Font;
import java.awt.FontMetrics;
import java.awt.Graphics;
import java.awt.Color;

allmän klass PlayGameScreen utökar JPanel {
standard referens-ID
privata statisk sista långa serialVersionUID = 1L;

globala variabler
privata int screenWidth, screenHeight;
privata boolean isSplash = sant;
privata sträng meddelande = "Flappy fågeln";
privat Font primaryFont = nya teckensnitt ("Goudy Stout", Font.BOLD, 56), failFont = nya teckensnitt ("kaliber", Font.BOLD, 56);
privata int messageWidth = 0;
privat BottomPipe bp1, bp2;
privat TopPipe tp1, tp2;

/**
* Standardkonstruktor för klassen PlayGameScreen
*/
offentliga PlayGameScreen (int screenWidth, int screenHeight, boolean isSplash) {
this.screenWidth = screenWidth;
this.screenHeight = screenHeight;
this.isSplash = isSplash;
}

/**
* Manuellt styra vad dras på denna JPanel genom att anropa metoden paintComponent
* med graphics-objektet och målning med objektet
*/
public void paintComponent (Graphics g) {
super.paintComponent(g);

g.setColor (ny färg (89, 81, 247)); färg för den blå himlen
g.fillRect (0, 0, screenWidth, screenHeight * 7/8); skapa den sky rektangeln
g.setColor (ny färg (147, 136, 9)); brun färg för marken
g.fillRect (0, screenHeight * 7/8, screenWidth, screenHeight/8); skapa den mark rektangeln
g.setColor(Color.BLACK); dividera Linjefärg
g.drawLine (0, screenHeight * 7/8, screenWidth, screenHeight * 7/8); dra skiljelinjen

objekt måste instantieras innan de är dras!
om (bp1! = null & & bp2! = null & & tp1! = null & & tp2! = null) {
g.drawImage(bp1.getPipe(), bp1.getX(), bp1.getY(), null);
g.drawImage(bp2.getPipe(), bp2.getX(), bp2.getY(), null);
g.drawImage(tp1.getPipe(), tp1.getX(), tp1.getY(), null);
g.drawImage(tp2.getPipe(), tp2.getX(), tp2.getY(), null);
}

behövs om primära teckensnittet inte finns
försök {
g.setFont(primaryFont);
FontMetrics mått = g.getFontMetrics(primaryFont);
messageWidth = metric.stringWidth(message);
}
fånga (undantag e) {
g.setFont(failFont);
FontMetrics mått = g.getFontMetrics(failFont);
messageWidth = metric.stringWidth(message);
}
g.drawString (meddelande, screenWidth/2-messageWidth/2, screenHeight/4);
}

/**
* När metoden för Playgamescreens globala BottomPipe variabler
* bp1 den första BottomPipe
* bp2 den andra BottomPipe
*/
public void setBottomPipe (BottomPipe bp1, BottomPipe bp2) {
This.BP1 = bp1;
This.bp2 = bp2;
}

/**
* När metoden för Playgamescreens globala TopPipe variabler
* tp1 den första TopPipe
* tp2 den andra TopPipe
*/
public void setTopPipe (TopPipe tp1, TopPipe tp2) {
This.TP1 = tp1;
This.TP2 = tp2;
}

/**
* Metod som kallas för att tolka ett meddelande på skärmen
* meddelande meddelandet att tolka
*/
public void sendText (String meddelande) {
This.Message = meddelande;
}
}

Se Steg
Relaterade Ämnen

Flappy fågeln Hat

Flappy fågeln är en mobil spel (utvecklat i 2013) vars mål är att ha användaren navigera en animerad fågel att flyga mellan gröna rör utan att träffa dem. Ju högre poäng, mer rören fågeln har passerat och det "bättre" spelare har gjort.Kapitalis...

Arduino-baserad Bi-color LED Matrix Flappy fågeln spel

Vi har byggt en hel del projekt med Bi-färg (rött och grönt) LED Matrix drivrutinsmodulen Kit från jolliFactory och har publicerat dem som instructables här. Var och en av dessa moduler använder två MAX7219 Display Driver ICs för att driva en Bi-colo...

Flappy fågeln penna

Flappy fågeln har blivit en berömd spel över hela världen. Men det är från AppStore (tår), jag ville ändå göra denna handledning för de människor som har denna och stipl njuta av det mycket! Hoppas du njuter!En tjej i min skola kom till skolan med tr...

Hur man får Flappy fågeln tillbaka

Steg 1: Gå till App Store Go to the app store. Och sedan klicka på köpt. Nästa hitta flappy fågeln i inköp. Slutligen trycker du på den och låt den ladda.Steg 2: Spela Flappy fågeln Enjoy...

Hur man får Flappy fågeln tillbaka för Android - nr falska

ända sedan Flappy fågeln tagits bort Play Store, tusentals av oss har försökt hitta den äkta varan igen. Många tänker "Varför sjutton jag bort det?" eller ens "varför inte jag hämta det?". Nu på grund av Flappy fågeln vurm köper folk f...

Hack Flappy fågeln på DIY Gamer Kit

Denna tutorial ska show dig hur till lek med och ändra inställningarna för Flappy fågeln spelet som ingår i DIY Gamer biblioteket.För denna tutorial behöver du en Gamer och en USB-kabel. Kontrollera att du har installerat Gamer biblioteket och att du...

Spara Flappy fågeln Legos

Hjälp! Flappy fågeln bröt sina vingar. Hjälpa honom att få bort fyren genom att bygga honom en flotte och få honom till sitt tropiska palmträd hem.Material du behöver:En hela lego set.Spara Flappy fågeln laget Bio:Alina PappasAlina är en junior grund...

LEGO Flappy fågeln mosaik

Här är en enkel guide till att bygga din egen Flappy fågeln...Steg 1: BasBörja du behöver 3 av varje av följande tegelstenar:1 brett svart2 bred grön1 bred vit4 bred grön1 brett svartoch en 8 och 1 bred platta.För dem enligt listan ovan. Djupet är in...

Hur man får tillbaka Flappy fågeln! (iOS)

Om du missade styggelse vet också som Flappy fågeln, här är sättet att få tillbaka Flappy fågeln* Du måste har fått det när det var ut OR ELSE detta brukar arbete! * * måste ha iOS 6 eller 7 *Steg 1: Gå till App Store Först gå till App Store och klic...

Hur till hacka Flappy fågeln

hur till hacka flappy fågeln på en rotad telefon.Steg 1: Kontrollera att din telefon är rotad du måste ha en rotad telefon att redigera apps.Steg 2: Kontrollera att du har Flappy fågelnSteg 3: Hämta fuska Droid detta kan hittas i appstoreSteg 4: Öppn...

Flappy fågeln alla hjärtans dag Pop Up-kort hur man (Flappy alla hjärtans dag) Kirigami 3D!

En snabb alla hjärtans dagskort jag gjort baserat på det populära spelet Flappy fågeln.Dela på FACEBOOK: http://on.fb.me/15TrVYfTWEET: http://bit.ly/15Ts5P6REDDIT: http://bit.ly/16qHt5LTUMBLR: http://bit.ly/10K8fhzHämta det gratis mönstret här: http:...

Lyckligaste fågel färg in flappy fågeln

i denna studie jag försökte hitta vilket är den lyckligaste flappy fågel färgenSteg 1: spela flappy fågeln 10 gånger med varje fågel detta är inte en verklig poäng min highscore är mycket lägre.Steg 2: ta genomsnittet och lägga den på nätetSteg 3: di...

Hur till vinna Flappy fågeln varje gång

Flappy fågeln, en oförklarligt populära spel, är dock av många också vara hopplöst svåra. Men de är helt fel. Med denna guide är din dagar scoring mindre sedan 100 över. En platina medalj blir ingenting jämfört med te poäng du kommer att vara att upp...

Hur man installerar flappy fågeln på Android, utan att någonsin ha det ursprungligen

nu när det inte finns många flappy fågeln instructables görs jag beslutat att lägga upp hur man får Flappy fågeln utan att någonsin hämta det innan det togs ner.Steg 1: Saker som behövs En dator, en Sd kortläsare eller USB-kontakten, Android och Inte...

Hur till hacka/fuska Flappy fågeln!

Krav~ Du måste vara jailbroken (jag har en instructable på hur man gör det om du inte är)~ Du måste ha iFile~ Du måste ha Flappy fågeln (uppenbarligen)Steg 1: Nära Flappy fågeln från arbetsuppgift direktörSteg 2: Öppna iFile och gör följande: ~ Gå ti...

Få Flappy fågeln på iOS

har du inte fått flappy fågeln medan det var populära? Ja nu kan du få det genom att använda din awesome vän som redan fått den.Steg 1: Gå till App Store Gå till App Store och gå till presenterade.Steg 2: Logga ut Logga med ditt Apple-ID och logga in...

Verkliga, spelbara Version av "Flappy fågeln" inuti en låda

jag gjorde denna verkliga, spelbar version av "Flappy fågeln" använder Arduino Duemilanove, 3 servomotorer, 2 knappar, en högtalare, reed switch och handfull sällsynta jordartsmetaller magneter.Först hitta en ruta för att göra spelet och två små...

Flappy fågeln vördnad för Arduino och 64 lysdioder

jag fick ett par av 8 x 8 LED matriser med posten igår. Så tillbringade jag tid lödning, felsökning, kodning och felsökning ett litet spel som är starkt inspirerad av den sena Flappy fågeln.Källkod och mer detaljer på GitHub: https://github.com/augus...

Slå Flappy fågeln

Steg 1: Spela det Spela spel flappy fågeln i android eller I telefon jag har en iPod 5Steg 2: Beat It Gå till hem skärm eller app valet på ta bort denSteg 3: gjortDu har nu slå flappy fågeln...