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

Steg 9: Fade operationen

Vid denna tidpunkt, vi har mycket av vad behövs för att få spelet insvept: rören går på skärmen, klasserna spelare och hinder är färdiga, klassen PlayGameScreen är nästan klar och vi är nästan klar med TopClass.

Detta steg handlar om att göra spel flödet bättre. Om vi inte använde detta, skulle vi ha en abrupt hoppa från en välkomstskärm till en spelskärmen och det skulle vara mycket obehagligt att spela. Metoden fadeOperation i TopClass kommer att utföra en "enkel" vissna till svart och fade-från-svart att starta spelet.

Fade operationen kommer utlösas med metoden actionPerformed. När källan till ActionEvent är knappen startGame, ändrar vi loopVar till false berätta spelet öglan för att sluta köra. Nästa kallar vi fadeOperation().

Den första delen av handstil fadeOperation() startar en ny tråd för att hantera förändringarna framöver. Inom den nya tråd run()-metoden, vi först ta bort knappen från primära innehållspanelen (topPanel) och panelen bilder och sedan uppdatera topPanel. Sedan skapar vi en tillfällig JPanel (kallas temp) som vi kommer att lägga ovanpå topPanel; Detta är panelen vi tona (kom ihåg Toppanel's bakgrunden är svart).

Vi skapar en ny variabel för att hålla alpha, sedan inställd temp's bakgrund på en transparent svart JPanel. Vi lägga till temp i topPanel och lägga till PaintGameScreen-förekomsten (pgs) tillbaka på toppen av det, följt av en uppdatera.

Vid denna punkt, vi behöver ett tag loop att utföra den faktiska vissna till svart. Som i spelet slingan, vi skapar en variabel för att hålla iteration tiden, men denna gång, while loop slutet tillstånd är när panelen temp alfavärde är 255 (helt transparent). Ställa in en IF-sats att berätta för oss hur ofta för att utföra ändringar. Jag använde sedan en enkel If-Else uttalande för att diktera hur toningen sker (mestadels linjärt här). Du kan göra vad du vill här. Efter detta kan du ställa in temp's bakgrund och uppdatera topPanel.

När vissna till svart är klar, vi ta bort allt från topPanel, lägger till panelen temp, skapa en ny instans av PlayGameScreen (Tvingande pgs), ta bort rubriktexten och lägga till pgs tillbaka till topPanel. För att tona från svart, utför vi i huvudsak åtgärden vissna till svart motsatt logik.

När du är klar måste vi informera spelet som det är tillåtet för att börja. Det gör skapat vi ett globalt objekt som kallas buildComplete. I slutet av fadeOperation avtryckare vi manuellt en ActionEvent på buildComplete.

Den sista förändringen vi gör på detta steg är att metoden actionPerformed. Vi skapar en ny villkorlig (annars-om) för buildComplete. Här, vi skapar en ny tråd, och i dess run()-metoden, vi ändra loopVar tillbaka till sant (tillåta spelklocka köra igen) och anropa metoden gameScreen, denna gång passerar i falsk - vi ser därför på nästa steg.

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
privata objekt buildComplete = ny objekt();

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) {
stoppa startbilden
loopVar = false;

fadeOperation();
}
annat if(e.getSource() == buildComplete) {
Gänga t = nya Thread() {
public void run() {
loopVar = sant;
tc.gameScreen(false);
}
};
t.start();
}
}

/**
* Utföra fade operation som sker innan rundor
*/
privata void fadeOperation() {
Gänga t = nya Thread() {
public void run() {
topPanel.remove(startGame);
topPanel.remove(pgs);
topPanel.revalidate();
topPanel.repaint();

panelen att blekna
JPanel temp = nya JPanel();
int alpha = 0; alfakanal variabel
temp.setBackground (ny färg (0, 0, 0, alfa)); transparent, svart JPanel
topPanel.add(temp);
topPanel.add(pgs);
topPanel.revalidate();
topPanel.repaint();

långa currentTime = System.currentTimeMillis();
långa startTime = currentTime;

While((system.currentTimeMillis() - startTime) > FADE_TIME_MILLIS || temp.getBackground().getAlpha()! = 255) {
IF((system.currentTimeMillis() - startTime) > UPDATE_DIFFERENCE/2) {
om (alpha < 255-10) {
alpha + = 10.
}
annat {
alpha = 255;
}

temp.setBackground (ny färg (0, 0, 0, alfa));

topPanel.revalidate();
topPanel.repaint();
startTime = System.currentTimeMillis();
}
}

topPanel.removeAll();
topPanel.add(temp);
PGS = nya PlayGameScreen (skärmbredd, SCREEN_HEIGHT, false);
pgs.sendText(""); ta bort rubriktext
topPanel.add(pgs);

While((system.currentTimeMillis() - startTime) > FADE_TIME_MILLIS || temp.getBackground().getAlpha()! = 0) {
IF((system.currentTimeMillis() - startTime) > UPDATE_DIFFERENCE/2) {
om (alfa > 10) {
alpha-= 10.
}
annat {
alpha = 0;
}

temp.setBackground (ny färg (0, 0, 0, alfa));

topPanel.revalidate();
topPanel.repaint();
startTime = System.currentTimeMillis();
}
}

actionPerformed (nya ActionEvent (buildComplete, -1, "Bygga avslutad"));
}
};

t.start();
}

/**
* 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;
}
}

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...