Java 開發打飛機小遊戲(附完整源碼)

2021-02-07 碼匠筆記
上圖

寫在前面

技術源於分享,所以今天抽空把自己之前用java做過的小遊戲整理貼出來給大家參考學習。java確實不適合寫桌面應用,這裡只是通過這個遊戲讓大家理解oop面向對象編程的過程,純屬娛樂。代碼寫的很簡單,也很容易理解,並且注釋寫的很清楚了,還有問題,自己私下去補課學習。

完整代碼敵飛機
import java.util.Random;


 敵飛機: 是飛行物,也是敵人

public class Airplane extends FlyingObject implements Enemy {
    private int speed = 3;  //移動步驟

    /** 初始化數據 */
    public Airplane(){
        this.image = ShootGame.airplane;
        width = image.getWidth();
        height = image.getHeight();
        y = -height;          
        Random rand = new Random();
        x = rand.nextInt(ShootGame.WIDTH - width);
    }

    /** 獲取分數 */
    @Override
    public int getScore() {  
        return 5;
    }

    /** //越界處理 */
    @Override
    public     boolean outOfBounds() {   
        return y>ShootGame.HEIGHT;
    }

    /** 移動 */
    @Override
    public void step() {   
        y += speed;
    }
}

分數獎勵
/** 
 * 獎勵 
 */  
public interface Award {  
    int DOUBLE_FIRE = 0;  //雙倍火力  
    int LIFE = 1;   //1條命  
    /** 獲得獎勵類型(上面的0或1) */  
    int getType();  
}

蜜蜂
import java.util.Random;  

/** 蜜蜂 */  
public class Bee extends FlyingObject implements Award{  
    private int xSpeed = 1;   //x坐標移動速度  
    private int ySpeed = 2;   //y坐標移動速度  
    private int awardType;    //獎勵類型  

    /** 初始化數據 */  
    public Bee(){  
        this.image = ShootGame.bee;  
        width = image.getWidth();  
        height = image.getHeight();  
        y = -height;  
        Random rand = new Random();  
        x = rand.nextInt(ShootGame.WIDTH - width);  
        awardType = rand.nextInt(2);   //初始化時給獎勵  
    }  

    /** 獲得獎勵類型 */  
    public int getType(){  
        return awardType;  
    }  

    /** 越界處理 */  
    @Override  
    public boolean outOfBounds() {  
        return y>ShootGame.HEIGHT;  
    }  

    /** 移動,可斜著飛 */  
    @Override  
    public void step() {        
        x += xSpeed;  
        y += ySpeed;  
        if(x > ShootGame.WIDTH-width){    
            xSpeed = -1;  
        }  
        if(x < 0){  
            xSpeed = 1;  
        }  
    }  
}

子彈類:是飛行物體
/** 
 * 子彈類:是飛行物 
 */  
public class Bullet extends FlyingObject {  
    private int speed = 3;  //移動的速度  

    /** 初始化數據 */  
    public Bullet(int x,int y){  
        this.x = x;  
        this.y = y;  
        this.image = ShootGame.bullet;  
    }  

    /** 移動 */  
    @Override  
    public void step(){     
        y-=speed;  
    }  

    /** 越界處理 */  
    @Override  
    public boolean outOfBounds() {  
        return y<-height;  
    }  

}

敵人的分數
/** 
 * 敵人,可以有分數 
 */  
public interface Enemy {  
    /** 敵人的分數  */  
    int getScore();  
}

飛行物(敵機,蜜蜂,子彈,英雄機)
import java.awt.image.BufferedImage;  

/** 
 * 飛行物(敵機,蜜蜂,子彈,英雄機) 
 */  
public abstract class FlyingObject {  
    protected int x;    //x坐標  
    protected int y;    //y坐標  
    protected int width;    //寬  
    protected int height;   //高  
    protected BufferedImage image;   //圖片  

    public int getX() {  
        return x;  
    }  

    public void setX(int x) {  
        this.x = x;  
    }  

    public int getY() {  
        return y;  
    }  

    public void setY(int y) {  
        this.y = y;  
    }  

    public int getWidth() {  
        return width;  
    }  

    public void setWidth(int width) {  
        this.width = width;  
    }  

    public int getHeight() {  
        return height;  
    }  

    public void setHeight(int height) {  
        this.height = height;  
    }  

    public BufferedImage getImage() {  
        return image;  
    }  

    public void setImage(BufferedImage image) {  
        this.image = image;  
    }  

    /** 
     * 檢查是否出界 
     * @return true 出界與否 
     */  
    public abstract boolean outOfBounds();  

    /** 
     * 飛行物移動一步 
     */  
    public abstract void step();  

    /** 
     * 檢查當前飛行物體是否被子彈(x,y)擊(shoot)中 
     * @param Bullet 子彈對象 
     * @return true表示被擊中了 
     */  
    public boolean shootBy(Bullet bullet){  
        int x = bullet.x;  //子彈橫坐標  
        int y = bullet.y;  //子彈縱坐標  
        return this.x<x && x<this.x+width && this.y<y && y<this.y+height;  
    }  

}

英雄機
import java.awt.image.BufferedImage;  

/** 
 * 英雄機:是飛行物  
 */  
public class Hero extends FlyingObject{  

    private BufferedImage[] images = {};  //英雄機圖片  
    private int index = 0;                //英雄機圖片切換索引  

    private int doubleFire;   //雙倍火力  
    private int life;   //命  

    /** 初始化數據 */  
    public Hero(){  
        life = 3;   //初始3條命  
        doubleFire = 0;   //初始火力為0  
        images = new BufferedImage[]{ShootGame.hero0, ShootGame.hero1}; //英雄機圖片數組  
        image = ShootGame.hero0;   //初始為hero0圖片  
        width = image.getWidth();  
        height = image.getHeight();  
        x = 150;  
        y = 400;  
    }  

    /** 獲取雙倍火力 */  
    public int isDoubleFire() {  
        return doubleFire;  
    }  

    /** 設置雙倍火力 */  
    public void setDoubleFire(int doubleFire) {  
        this.doubleFire = doubleFire;  
    }  

    /** 增加火力 */  
    public void addDoubleFire(){  
        doubleFire = 40;  
    }  

    /** 增命 */  
    public void addLife(){  //增命  
        life++;  
    }  

    /** 減命 */  
    public void subtractLife(){   //減命  
        life--;  
    }  

    /** 獲取命 */  
    public int getLife(){  
        return life;  
    }  

    /** 當前物體移動了一下,相對距離,x,y滑鼠位置  */  
    public void moveTo(int x,int y){     
        this.x = x - width/2;  
        this.y = y - height/2;  
    }  

    /** 越界處理 */  
    @Override  
    public boolean outOfBounds() {  
        return false;    
    }  

    /** 發射子彈 */  
    public Bullet[] shoot(){     
        int xStep = width/4;      //4半  
        int yStep = 20;  //步  
        if(doubleFire>0){  //雙倍火力  
            Bullet[] bullets = new Bullet[2];  
            bullets[0] = new Bullet(x+xStep,y-yStep);  //y-yStep(子彈距飛機的位置)  
            bullets[1] = new Bullet(x+3*xStep,y-yStep);  
            return bullets;  
        }else{      //單倍火力  
            Bullet[] bullets = new Bullet[1];  
            bullets[0] = new Bullet(x+2*xStep,y-yStep);    
            return bullets;  
        }  
    }  

    /** 移動 */  
    @Override  
    public void step() {  
        if(images.length>0){  
            image = images[index++/10%images.length];  //切換圖片hero0,hero1  
        }  
    }  

    /** 碰撞算法 */  
    public boolean hit(FlyingObject other){  

        int x1 = other.x - this.width/2;                 //x坐標最小距離  
        int x2 = other.x + this.width/2 + other.width;   //x坐標最大距離  
        int y1 = other.y - this.height/2;                //y坐標最小距離  
        int y2 = other.y + this.height/2 + other.height; //y坐標最大距離  

        int herox = this.x + this.width/2;               //英雄機x坐標中心點距離  
        int heroy = this.y + this.height/2;              //英雄機y坐標中心點距離  

        return herox>x1 && herox<x2 && heroy>y1 && heroy<y2;   //區間範圍內為撞上了  
    }  

}

遊戲啟動主類
import java.awt.Font;  
import java.awt.Color;  
import java.awt.Graphics;  
import java.awt.event.MouseAdapter;  
import java.awt.event.MouseEvent;  
import java.util.Arrays;  
import java.util.Random;  
import java.util.Timer;  
import java.util.TimerTask;  
import java.awt.image.BufferedImage;  

import javax.imageio.ImageIO;  
import javax.swing.ImageIcon;  
import javax.swing.JFrame;  
import javax.swing.JPanel;  
/**
 * 
 */
public class ShootGame extends JPanel {  
    public static final int WIDTH = 400; // 面板寬  
    public static final int HEIGHT = 654; // 面板高  
    /** 遊戲的當前狀態: START RUNNING PAUSE GAME_OVER */  
    private int state;  
    private static final int START = 0;  
    private static final int RUNNING = 1;  
    private static final int PAUSE = 2;  
    private static final int GAME_OVER = 3;  

    private int score = 0; // 得分  
    private Timer timer; // 定時器  
    private int intervel = 1000 / 100; // 時間間隔(毫秒)  

    public static BufferedImage background;  
    public static BufferedImage start;  
    public static BufferedImage airplane;  
    public static BufferedImage bee;  
    public static BufferedImage bullet;  
    public static BufferedImage hero0;  
    public static BufferedImage hero1;  
    public static BufferedImage pause;  
    public static BufferedImage gameover;  

    private FlyingObject[] flyings = {}; // 敵機數組  
    private Bullet[] bullets = {}; // 子彈數組  
    private Hero hero = new Hero(); // 英雄機  

    static { // 靜態代碼塊,初始化圖片資源  
        try {  
            background = ImageIO.read(ShootGame.class  
                    .getResource("background.png"));  
            start = ImageIO.read(ShootGame.class.getResource("start.png"));  
            airplane = ImageIO  
                    .read(ShootGame.class.getResource("airplane.png"));  
            bee = ImageIO.read(ShootGame.class.getResource("bee.png"));  
            bullet = ImageIO.read(ShootGame.class.getResource("bullet.png"));  
            hero0 = ImageIO.read(ShootGame.class.getResource("hero0.png"));  
            hero1 = ImageIO.read(ShootGame.class.getResource("hero1.png"));  
            pause = ImageIO.read(ShootGame.class.getResource("pause.png"));  
            gameover = ImageIO  
                    .read(ShootGame.class.getResource("gameover.png"));  
        } catch (Exception e) {  
            e.printStackTrace();  
        }  
    }  

    /** 畫 */  
    @Override  
    public void paint(Graphics g) {  
        g.drawImage(background, 0, 0, null); // 畫背景圖  
        paintHero(g); // 畫英雄機  
        paintBullets(g); // 畫子彈  
        paintFlyingObjects(g); // 畫飛行物  
        paintScore(g); // 畫分數  
        paintState(g); // 畫遊戲狀態  
    }  

    /** 畫英雄機 */  
    public void paintHero(Graphics g) {  
        g.drawImage(hero.getImage(), hero.getX(), hero.getY(), null);  
    }  

    /** 畫子彈 */  
    public void paintBullets(Graphics g) {  
        for (int i = 0; i < bullets.length; i++) {  
            Bullet b = bullets[i];  
            g.drawImage(b.getImage(), b.getX() - b.getWidth() / 2, b.getY(),  
                    null);  
        }  
    }  

    /** 畫飛行物 */  
    public void paintFlyingObjects(Graphics g) {  
        for (int i = 0; i < flyings.length; i++) {  
            FlyingObject f = flyings[i];  
            g.drawImage(f.getImage(), f.getX(), f.getY(), null);  
        }  
    }  

    /** 畫分數 */  
    public void paintScore(Graphics g) {  
        int x = 10; // x坐標  
        int y = 25; // y坐標  
        Font font = new Font(Font.SANS_SERIF, Font.BOLD, 22); // 字體  
        g.setColor(new Color(0xFF0000));  
        g.setFont(font); // 設置字體  
        g.drawString("SCORE:" + score, x, y); // 畫分數  
        y=y+20; // y坐標增20  
        g.drawString("LIFE:" + hero.getLife(), x, y); // 畫命  
    }  

    /** 畫遊戲狀態 */  
    public void paintState(Graphics g) {  
        switch (state) {  
        case START: // 啟動狀態  
            g.drawImage(start, 0, 0, null);  
            break;  
        case PAUSE: // 暫停狀態  
            g.drawImage(pause, 0, 0, null);  
            break;  
        case GAME_OVER: // 遊戲終止狀態  
            g.drawImage(gameover, 0, 0, null);  
            break;  
        }  
    }  

    public static void main(String[] args) {  
        JFrame frame = new JFrame("Fly");  
        ShootGame game = new ShootGame(); // 面板對象  
        frame.add(game); // 將面板添加到JFrame中  
        frame.setSize(WIDTH, HEIGHT); // 設置大小  
        frame.setAlwaysOnTop(true); // 設置其總在最上  
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 默認關閉操作  
        frame.setIconImage(new ImageIcon("images/icon.jpg").getImage()); // 設置窗體的圖標  
        frame.setLocationRelativeTo(null); // 設置窗體初始位置  
        frame.setVisible(true); // 儘快調用paint  

        game.action(); // 啟動執行  
    }  

    /** 啟動執行代碼 */  
    public void action() {  
        // 滑鼠監聽事件  
        MouseAdapter l = new MouseAdapter() {  
            @Override  
            public void mouseMoved(MouseEvent e) { // 滑鼠移動  
                if (state == RUNNING) { // 運行狀態下移動英雄機--隨滑鼠位置  
                    int x = e.getX();  
                    int y = e.getY();  
                    hero.moveTo(x, y);  
                }  
            }  

            @Override  
            public void mouseEntered(MouseEvent e) { // 滑鼠進入  
                if (state == PAUSE) { // 暫停狀態下運行  
                    state = RUNNING;  
                }  
            }  

            @Override  
            public void mouseExited(MouseEvent e) { // 滑鼠退出  
                if (state == RUNNING) { // 遊戲未結束,則設置其為暫停  
                    state = PAUSE;  
                }  
            }  

            @Override  
            public void mouseClicked(MouseEvent e) { // 滑鼠點擊  
                switch (state) {  
                case START:  
                    state = RUNNING; // 啟動狀態下運行  
                    break;  
                case GAME_OVER: // 遊戲結束,清理現場  
                    flyings = new FlyingObject[0]; // 清空飛行物  
                    bullets = new Bullet[0]; // 清空子彈  
                    hero = new Hero(); // 重新創建英雄機  
                    score = 0; // 清空成績  
                    state = START; // 狀態設置為啟動  
                    break;  
                }  
            }  
        };  
        this.addMouseListener(l); // 處理滑鼠點擊操作  
        this.addMouseMotionListener(l); // 處理滑鼠滑動操作  

        timer = new Timer(); // 主流程控制  
        timer.schedule(new TimerTask() {  
            @Override  
            public void run() {  
                if (state == RUNNING) { // 運行狀態  
                    enterAction(); // 飛行物入場  
                    stepAction(); // 走一步  
                    shootAction(); // 英雄機射擊  
                    bangAction(); // 子彈打飛行物  
                    outOfBoundsAction(); // 刪除越界飛行物及子彈  
                    checkGameOverAction(); // 檢查遊戲結束  
                }  
                repaint(); // 重繪,調用paint()方法  
            }  

        }, intervel, intervel);  
    }  

    int flyEnteredIndex = 0; // 飛行物入場計數  

    /** 飛行物入場 */  
    public void enterAction() {  
        flyEnteredIndex++;  
        if (flyEnteredIndex % 40 == 0) { // 400毫秒生成一個飛行物--10*40  
            FlyingObject obj = nextOne(); // 隨機生成一個飛行物  
            flyings = Arrays.copyOf(flyings, flyings.length + 1);  
            flyings[flyings.length - 1] = obj;  
        }  
    }  

    /** 走一步 */  
    public void stepAction() {  
        for (int i = 0; i < flyings.length; i++) { // 飛行物走一步  
            FlyingObject f = flyings[i];  
            f.step();  
        }  

        for (int i = 0; i < bullets.length; i++) { // 子彈走一步  
            Bullet b = bullets[i];  
            b.step();  
        }  
        hero.step(); // 英雄機走一步  
    }  

    /** 飛行物走一步 */  
    public void flyingStepAction() {  
        for (int i = 0; i < flyings.length; i++) {  
            FlyingObject f = flyings[i];  
            f.step();  
        }  
    }  

    int shootIndex = 0; // 射擊計數  

    /** 射擊 */  
    public void shootAction() {  
        shootIndex++;  
        if (shootIndex % 30 == 0) { // 300毫秒發一顆  
            Bullet[] bs = hero.shoot(); // 英雄打出子彈  
            bullets = Arrays.copyOf(bullets, bullets.length + bs.length); // 擴容  
            System.arraycopy(bs, 0, bullets, bullets.length - bs.length,  
                    bs.length); // 追加數組  
        }  
    }  

    /** 子彈與飛行物碰撞檢測 */  
    public void bangAction() {  
        for (int i = 0; i < bullets.length; i++) { // 遍歷所有子彈  
            Bullet b = bullets[i];  
            bang(b); // 子彈和飛行物之間的碰撞檢查  
        }  
    }  

    /** 刪除越界飛行物及子彈 */  
    public void outOfBoundsAction() {  
        int index = 0; // 索引  
        FlyingObject[] flyingLives = new FlyingObject[flyings.length]; // 活著的飛行物  
        for (int i = 0; i < flyings.length; i++) {  
            FlyingObject f = flyings[i];  
            if (!f.outOfBounds()) {  
                flyingLives[index++] = f; // 不越界的留著  
            }  
        }  
        flyings = Arrays.copyOf(flyingLives, index); // 將不越界的飛行物都留著  

        index = 0; // 索引重置為0  
        Bullet[] bulletLives = new Bullet[bullets.length];  
        for (int i = 0; i < bullets.length; i++) {  
            Bullet b = bullets[i];  
            if (!b.outOfBounds()) {  
                bulletLives[index++] = b;  
            }  
        }  
        bullets = Arrays.copyOf(bulletLives, index); // 將不越界的子彈留著  
    }  

    /** 檢查遊戲結束 */  
    public void checkGameOverAction() {  
        if (isGameOver()==true) {  
            state = GAME_OVER; // 改變狀態  
        }  
    }  

    /** 檢查遊戲是否結束 */  
    public boolean isGameOver() {  

        for (int i = 0; i < flyings.length; i++) {  
            int index = -1;  
            FlyingObject obj = flyings[i];  
            if (hero.hit(obj)) { // 檢查英雄機與飛行物是否碰撞  
                hero.subtractLife(); // 減命  
                hero.setDoubleFire(0); // 雙倍火力解除  
                index = i; // 記錄碰上的飛行物索引  
            }  
            if (index != -1) {  
                FlyingObject t = flyings[index];  
                flyings[index] = flyings[flyings.length - 1];  
                flyings[flyings.length - 1] = t; // 碰上的與最後一個飛行物交換  

                flyings = Arrays.copyOf(flyings, flyings.length - 1); // 刪除碰上的飛行物  
            }  
        }  

        return hero.getLife() <= 0;  
    }  

    /** 子彈和飛行物之間的碰撞檢查 */  
    public void bang(Bullet bullet) {  
        int index = -1; // 擊中的飛行物索引  
        for (int i = 0; i < flyings.length; i++) {  
            FlyingObject obj = flyings[i];  
            if (obj.shootBy(bullet)) { // 判斷是否擊中  
                index = i; // 記錄被擊中的飛行物的索引  
                break;  
            }  
        }  
        if (index != -1) { // 有擊中的飛行物  
            FlyingObject one = flyings[index]; // 記錄被擊中的飛行物  

            FlyingObject temp = flyings[index]; // 被擊中的飛行物與最後一個飛行物交換  
            flyings[index] = flyings[flyings.length - 1];  
            flyings[flyings.length - 1] = temp;  

            flyings = Arrays.copyOf(flyings, flyings.length - 1); // 刪除最後一個飛行物(即被擊中的)  

            // 檢查one的類型(敵人加分,獎勵獲取)  
            if (one instanceof Enemy) { // 檢查類型,是敵人,則加分  
                Enemy e = (Enemy) one; // 強制類型轉換  
                score += e.getScore(); // 加分  
            } else { // 若為獎勵,設置獎勵  
                Award a = (Award) one;  
                int type = a.getType(); // 獲取獎勵類型  
                switch (type) {  
                case Award.DOUBLE_FIRE:  
                    hero.addDoubleFire(); // 設置雙倍火力  
                    break;  
                case Award.LIFE:  
                    hero.addLife(); // 設置加命  
                    break;  
                }  
            }  
        }  
    }  

    /** 
     * 隨機生成飛行物 
     *  
     * @return 飛行物對象 
     */  
    public static FlyingObject nextOne() {  
        Random random = new Random();  
        int type = random.nextInt(20); // [0,20)  
        if (type < 4) {  
            return new Bee();  
        } else {  
            return new Airplane();  
        }  
    }  
}

相關焦點

  • Java打飛機小遊戲(附完整源碼)
    java確實不適合寫桌面應用,這裡只是通過這個遊戲讓大家理解oop面向對象編程的過程,純屬娛樂。代碼寫的很簡單,也很容易理解,並且注釋寫的很清楚了,還有問題,自己私下去補課學習。完整代碼敵飛機import java.util.Random; 敵飛機: 是飛行物,也是敵人public class Airplane extends FlyingObject implements Enemy {    private int speed = 3;  //移動步驟    /** 初始化數據 */    public Airplane(){
  • 用 Java 開發一個打飛機小遊戲(附完整源碼)
    完整代碼敵飛機import java.util.Random; 敵飛機: 是飛行物,也是敵人public class          int yStep = 20;  //步          if(doubleFire>0){  //雙倍火力              Bullet[] bullets = new Bullet[2];              bullets[0] = new Bullet(x+xStep,y-yStep);  //y-yStep(子彈距飛機的位置
  • 「附完整源碼」Java 開發打飛機小遊戲【文末送書】
    文末送書~直接上圖寫在前面技術源於分享,所以今天抽空把自己之前用java做過的小遊戲整理貼出來給大家參考學習。java確實不適合寫桌面應用,這裡只是通過這個遊戲讓大家理解oop面向對象編程的過程,純屬娛樂。代碼寫的很簡單,也很容易理解,並且注釋寫的很清楚了,還有問題,自己私下去補課學習。
  • 手遊app開發入門教程之飛機小遊戲
    小編最近想玩一下射擊類的空戰飛機遊戲,看到新手遊裡有幾款,索性下載玩了玩,真是感覺垃圾啊,滿屏的「首充」啊、「禮包」啊在晃蕩,如下圖:以後沒有好網遊攻略的時候,超仔給大家陸續提供一些簡單的安卓手遊app開發入門教程,咱們今天就來個飛機小遊戲的製作吧。
  • 「二開可商用」基於java的B2B2C uniapp多商戶商城源碼
    JooLun uniapp多商戶商城源碼前端採用uniapp技術開發,後端採用流行的微服務技術,從底層設計開始已經為二開打好的基礎,二開可行性是非常高的,並且所有代碼的每個欄位都有注釋說明,二開起來真的不要太方便。
  • java多用戶分離式商城源碼(前端+後臺)-JooLun快速開發平臺
    JooLun Mall是採用Java語言開發的多用戶商城系統,這裡的多用戶指的是多租戶、多公眾號、多小程序管理,也可以說是多租戶單店鋪的小程序商城源碼。採用Sping Cloud微服務前後端分離技術的框架。擁有前端+後臺完整的0加密原始碼以及教程文檔。
  • 多牛軟體:直播APP源碼開發核心功用在哪幾個方面
    但是不同於其他APP的製作,直播APP源碼開發的邏輯功用更為雜亂。因此在開發進程中,有以下幾點需求留意:1、視頻的直播質量直播APP的開發,需求確保視頻能夠正常觀看,防止在網絡信號弱的環境下,呈現視頻加載異常或是用戶需求緩存的狀況,不然就會大大降低用戶體會。
  • Java中常用的七個阻塞隊列第二篇DelayQueue源碼介紹
    Java中常用的七個阻塞隊列第二篇DelayQueue源碼介紹通過前面兩篇文章,我們對隊列有了了解及已經認識了常用阻塞隊列中的三個了。本篇我們繼續介紹剩下的幾個隊列。本文主要內容:通過源碼學習Delayqueue及理解Dqueue並用代碼簡單演示使用場景。
  • 一對一直播源碼開發的技術框架
    整套一對一直播源碼共涉及三個端,也就是說,在進行一對一直播源碼開發時,我們要從用戶端、主播端和伺服器端進行討論。1.用戶端用戶可自行選擇對方(主播)的性別、連麥類型(語音、視頻)和每分鐘所需支付的價格,一對一直播源碼通過一對一軟體進行用戶匹配,最長匹配時間可在後臺進行設置若最長匹配時間段內沒有主播進行搶聊,用戶方將被提示「重新匹配」或「等會再來」在用戶發起匹配前,系統會自動對用戶帳戶餘額進行監測
  • 一文解密,php短視頻源碼是什麼
    所謂的php短視頻源碼,大多是指管理後臺開發語言為php的短視頻源碼,實際上,「php短視頻源碼」是個偽命題,沒有完全由php開發語言寫的短視頻源碼,在安卓端、IOS端以及管理後端的軟體源碼,都是由不同的開發語言組合而成的。
  • 反射 — Java 高級開發必須懂的
    一、Class類的使用1、萬事萬物皆對象,(當然,基本數據類型,靜態成員不是面向對象(屬於類的)),所以我們創建的每一個類也都是對象,即類本身是java.lang.Class類的實例對象,但是這些對象都不需要new出來,因為java.lang.Class類的構造方法是私有的2、任何一個類都是Class類的實例對象,這個實例對象有三種表示方式
  • 【福利來了】B站 Java 精選視頻,都幫你整理好了,拿去用!!!
    大家好,今天幫大家整理了一下b站上java相關的精華視頻,供大家使用,文末有福利!!!設計模式尚矽谷韓順平-強烈推薦https://www.bilibili.com/video/av57936239四、Java源碼Java源碼分析
  • 直播系統開發中,直播源碼起到的作用有哪些?
    直播系統的需求比以往要火熱,直播源碼技術不斷前進,儘管用戶總流量紅利期已過,但網絡直播平臺已經進入成熟的成長期。在現場直播中,現場直播源碼功能的多樣性是在視頻直播市場中出彩的關鍵。直播源開發作為直播系統的脊梁骨幹。那麼直播系統開發中,直播源碼起到的作用有哪些?
  • Spring源碼解析之源碼的下載編譯
    老粉應該知道了,筆者最近剛上架技術生涯的第一本書《Java源碼模擬面試解析指南 》。於是趁著年輕時還有時間修福報,準備再做一個 Spring源碼面試指南。相比於之前是直接閱讀引入jar包的方式來研讀 JDK 源碼,由於框架源碼的複雜性及強可插拔性,一般將源碼編譯到本地,由此便可以邊研讀源碼邊加自由地注釋,方便調試程序等。首先進入 spring 官方倉庫,fork 一份倉庫到自己帳號下,方便自己提交。
  • 利用教育源碼進行線上教育平臺開發要有具體計劃
    隨著線上教育越來越融入到我們的工作和生活中,讓我們的學習和生活也發生了大的變化,而且利用教育源碼進行線上教育平臺開發後,有越來越多的人選擇線上教育這種學習和培訓方式,但是我們知道,線上教育平臺開發的技術要求比較高,那麼如何進行開發呢?
  • 教育類APP源碼,在線教育源碼,網校源碼開發模式主要有這五大類
    隨著時代的發展,傳統教育培訓機構在移動網際網路衝擊下,很多企業都開始轉型定製開發教育類APP軟體,伴隨著「直播+教育」的風靡,連同直播教育原始碼一直以來始終保持火熱。
  • Java案例_猜數字小遊戲
    做一個猜數字的小遊戲,雖然程序簡單,但其中包含的原理值得思考!
  • 直播軟體源碼搭建直播平臺,源碼考察和開發階段要這麼做才行
    直播軟體源碼如果要開發直播軟體,直播軟體源碼是必不可少的,如今也已經有很多現成的源碼了,如果能選擇好一款優質的源碼,平臺可以很快的搭建起來,本文來看看怎樣進行直播平臺的開發搭建一、對直播軟體源碼服務商的考察很重要如果要開發一款直播軟體系統,對於直播軟體源碼的選擇要多上點心。可以對市場上的源碼開發服務商進行實地考察,了解開發服務商的實力,源碼的完整性、穩定性等。1.
  • 開發屬於自己的第一款IDEA插件!
    本文轉載自【微信公眾號:java進階架構師,ID:java_jiagoushi】經微信公眾號授權轉載,如需轉載與原文作者聯繫作者:木杉http://imushan.com/寫Java代碼的時候,經常會涉及到重複性的操作