自由飞翔之小鸟

news2024/9/27 17:29:05

一、创建文件、包、类、插入图片文件

二、app包 

1、Gameapp类(运行游戏)

 

package app;
 
import main.GameFrame;
 
public class Gameapp {
    public static void main(String[] args) {//游戏的入口
        new GameFrame();
    }
}

三、main包

1、Barrier(障碍物类

package main;
 
import util.Constant;
import util.GameUtil;
 
import java.awt.*;
import java.awt.image.BufferedImage;
import java.util.Random;
 
/**
 * 障碍物类
 */
public class Barrier {
 
 
    //矩形参数
    private Rectangle rect;
 
    private boolean mob = true;
 
    //障碍物移动速度
    private int speed = 3;
    //障碍物需要的三个图片
    private static BufferedImage[] img;
 
    //障碍物的状态
    private boolean visible;
 
 
    static {
        final int COUNT = 3;
        //类加载的时候将三个图片初始化
        img = new BufferedImage[COUNT];
        for (int i = 0; i < COUNT; i++) {
            img[i] = GameUtil.loadBufferedImage(Constant.BARRIER_IMG_PATH[i]);
        }
    }
 
    //位置
    private int x, y;
    //宽度和高度
    private int width, height;
    //障碍物的类型
    private int type;
    public static final int TYPE_TOP_NORMAL = 0;
    public static final int TYPE_BOTTOM_NORMAL = 2;
    public static final int TYPE_HOVER_NORMAL = 4;
    public static final int TYPE_MOBILE = 6;
 
    //获得障碍物的宽度和高度
    public static final int BARRIRE_WIDTH = img[0].getWidth();
    public static final int BARRIRE_HEIGHT = img[0].getHeight();
    public static final int BARRIRE_HEAD_WIDTH = img[1].getWidth();
    public static final int BARRIRE_HEAD_HEIGHT = img[1].getHeight();
 
    public Barrier() {
 
        rect = new Rectangle();
 
    }
 
    public Barrier(int x, int y, int height, int type) {
        this.x = x;
        this.y = y;
        this.height = height;
        this.type = type;
        this.width = BARRIRE_WIDTH;
    }
 
    //根据不同的类型绘制障碍物
    public void draw(Graphics g) {
        switch (type) {
            case TYPE_TOP_NORMAL:
                drawTopMormal(g);
                break;
            case TYPE_BOTTOM_NORMAL:
                drawNomalTop(g);
                break;
            case TYPE_HOVER_NORMAL:
                drawHoverNormal(g);
                break;
            case TYPE_MOBILE:
                drawMobile(g);
                break;
        }
 
    }
 
    //绘制从上向下的障碍物
    private void drawTopMormal(Graphics g) {
        //求出所需要的障碍物的块数
        int count = (height - BARRIRE_HEAD_HEIGHT) / BARRIRE_HEIGHT + 1;
        //for循坏绘制障碍物
        for (int i = 0; i < count; i++) {
            g.drawImage(img[0], x, y + i * BARRIRE_HEIGHT, null);
        }
 
        //绘制头
        int y = height - BARRIRE_HEAD_HEIGHT;
        g.drawImage(img[2], x - (BARRIRE_HEAD_WIDTH - BARRIRE_WIDTH) / 2, y, null);
        x -= speed;
        if (x < 50) {
            visible = false;
        }
        rect(g);
 
 
    }
 
    //绘制从下向上的障碍物
    private void drawNomalTop(Graphics g) {
        //求出所需要的障碍物的块数
        int count = height / BARRIRE_HEIGHT + 1;
        //for循环绘制障碍物
        for (int i = 0; i < count; i++) {
            g.drawImage(img[0], x, Constant.FRAM_HEIGNT - i * BARRIRE_HEIGHT, null);
        }
        //绘制头
        int y = Constant.FRAM_HEIGNT - height;
        g.drawImage(img[1], x - (BARRIRE_HEAD_WIDTH - BARRIRE_WIDTH) / 2, y, null);
        x -= speed;
        if (x < -50) {
            visible = false;
        }
        rect(g);
    }
    //绘制中间的障碍物
    private void drawHoverNormal(Graphics g) {
        //求出所需要的障碍物的块数
        int count = (height-BARRIRE_HEAD_HEIGHT)/BARRIRE_HEIGHT;
        //绘制上头
        g.drawImage(img[1],x,y,null);
        //for循环绘制障碍物
        for (int i = 0; i < count; i++) {
            g.drawImage(img[0], x, y+BARRIRE_HEAD_HEIGHT+i*BARRIRE_HEIGHT, null);
        }
        rect(g);
 
        //绘制下头
        int y11 = y+height-BARRIRE_HEAD_HEIGHT;
        g.drawImage(img[2],x,y11,null);
        x -= speed;
        if (x < -50) {
            visible = false;
        }
    }
 
    //绘制移动的障碍物
    private void drawMobile(Graphics g) {
        //求出所需要的障碍物的块数
        int count = (height-BARRIRE_HEAD_HEIGHT)/BARRIRE_HEIGHT;
        //绘制上头
        g.drawImage(img[1],x,y,null);
        //for循环绘制障碍物
        for (int i = 0; i < count; i++) {
            g.drawImage(img[0], x, y+BARRIRE_HEAD_HEIGHT+i*BARRIRE_HEIGHT, null);
        }
        rect(g);
 
        //绘制下头
        int y11 = y+height-BARRIRE_HEAD_HEIGHT;
        g.drawImage(img[2],x,y11,null);
        x -= speed;
        if (x < -50) {
            visible = false;
        }
 
        if (mob) {
            y+=5;
            if (y >= 250) {
                mob=false;
            }
        }else if (!mob){
            y-=5;
            if (y <= 100) {
                mob=true;
            }
        }
    }
 
    /**
     * 绘制障碍物碰撞矩形
     *
     * @return
     */
    public void rect(Graphics g) {
        int x1 = this.x;
        int y1 = this.y;
        int w1 = img[0].getWidth();
//        g.setColor(Color.blue);
//        g.drawRect(x1, y1, w1, height);
        setRecyangle(x1, y1, w1, height);
    }
 
    /**
     * 障碍物的碰撞矩形参数
     *
     * @return
     */
    public void setRecyangle(int x, int y, int width, int height) {
        rect.x = x;
        rect.y = y;
        rect.width = width;
        rect.height = height;
    }
 
 
    //判断什么时候绘制下一组障碍物
    public boolean isInFrame() {
        return 600 - x > 150;
    }
 
    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 getHeight() {
        return height;
    }
 
    public void setHeight(int height) {
        this.height = height;
    }
 
    public int getType() {
        return type;
    }
 
    public void setType(int type) {
        this.type = type;
    }
 
    public boolean isVisible() {
        return visible;
    }
 
    public void setVisible(boolean visible) {
        this.visible = visible;
    }
 
    public Rectangle getRect() {
        return rect;
    }
}

2、Barrierpool(管理障碍物数量) 

package main;
 
 
import java.util.ArrayList;
import java.util.List;
 
/**
 * 为了避免反复的创建和销毁对象,使用对象池来提前创建好一些对象。
 * 使用的时候从池中获得,使用完毕后,归还
 */
public class Barrierpool {
    //用于管理池中所有对象的容器
    private static List<Barrier> pool = new ArrayList<>();
    //池中初始的对象个数
    public static final int initCount = 16;
    //对象池中最大个数
    public static final int maxCOunt = 20;
 
    static {
        //初始化池中的对象
        for (int i = 0; i < initCount; i++) {
            pool.add(new Barrier());
        }
    }
 
 
    /**
     * 从池中获取一个对象
     */
    public static Barrier getPool(){
        int size = pool.size();
        //如果池中有对象才可以拿
        if (size > 0) {
            //移除并返回对象
            System.out.println("拿走一个");
            return pool.remove(size-1);
        }else {
            //池中没有对象了 只能new
            System.out.println("新的对象");
            return new Barrier();
        }
    }
 
 
    /**
     * 将对象归还容器中
     */
    public static void setPool(Barrier barrier){
        if (pool.size() < maxCOunt) {
            pool.add(barrier);
            System.out.println("容器归还了");
        }
    }
 
 
}

 3、Bird(小鸟类)

package main;
 
 
import static util.Constant.*;
import util.GameUtil;
import java.awt.*;
import java.awt.image.BufferedImage;
 
/**
 * 小鸟类
 */
public class Bird {
 
    //小鸟矩形对象
    private Rectangle rect;
 
    //小鸟加速度
    private int acceleration;
 
    //小鸟的生命
    public boolean life = true;
 
    //存放小鸟图片
    private BufferedImage[] images;
    public static final int BIRD_IMG_COUNT = 3;
    //鸟的状态
    private int state;
    public static final int STATE_NORMAR = 0;//平着飞
    public static final int STATE_UP = 1;//向上飞
    public static final int STATE_DOWN = 2;//向下飞
 
    //小鸟的位置
    private int x=200,y=200;
 
 
    //小鸟移动方向 上下
    private boolean up=false,down=false;
 
    //小鸟移动速度
    private int speed=4;
 
 
    //构造方法中对资源初始化
    public Bird() {
        images = new BufferedImage[BIRD_IMG_COUNT];
        for (int i = 0; i < BIRD_IMG_COUNT; i++) {
            images[i] = GameUtil.loadBufferedImage(BIRD_IMG[i]);
        }
 
        int w = images[0].getWidth();
        int h = images[0].getHeight();
        rect = new Rectangle(w,h);
 
    }
 
    //绘制小鸟
    public void draw(Graphics g) {
 
        flyLogic();
 
        g.drawImage(images [state], x, y, null);
 
        //绘制小鸟的矩形
        g.drawRect(x,y,(int)rect.getWidth(), rect.height);
        rect.x=this.x;
        rect.y=this.y;
    }
 
 
 
    //控制小鸟移动方向
    public void flyLogic(){
        if (up){
            acceleration--;
            y+=acceleration;
            if (acceleration < -10) {
                acceleration=-10;
            }
            if (y<20){
                y=20;
                acceleration=0;
            }
        }
        if (!up){
            acceleration++;
            y+=acceleration;
            if (acceleration > 10) {
                acceleration=10;
            }
            if (y>475){
                y=475;
                acceleration=0;
            }
        }
 
    }
 
 
 
 
    public void fly(int fly){
        switch (fly){
            case 1:
                state=1;
                up=true;
                break;
            case 5:
                state=2;
                up=false;
                break;
        }
    }
 
    public Rectangle getRect() {
        return rect;
    }
 
/**
 * 重新绘制小鸟的位置
 */
public void  restartDraw(){
    life=true;
    x=200;
    y=200;
}
 
}

4、Cloud(云彩类)

package main;
 
import java.awt.*;
import java.awt.image.BufferedImage;
 
/**
 * 云彩类
 */
public class Cloud {
    //云彩图片
    private BufferedImage img;
    //云彩速度
    private  int speed;
    //云彩的位置
    private  int x,y;
 
    public Cloud(){}
 
    public Cloud(BufferedImage img, int speed, int x, int y) {
        this.img = img;
        this.speed = speed;
        this.x = x;
        this.y = y;
    }
 
    public void draw(Graphics g){
        x-=speed;
        g.drawImage(img,x,y,null);
    }
    /**
     * 用于判断云彩是否飞出屏幕以外
     */
    public boolean isOutFrame(){
        if (x < -100) {
            return true;
        }
        return false;
    }
 
}

5、GameBackGround(游戏背景类)

package main;
 
import static util.Constant.*;
 
import util.Constant;
import util.GameUtil;
 
import java.awt.*;
import java.awt.image.BufferedImage;
 
/**
 * 游戏背景类
 */
public class GameBackGround {
    //背景需要的资源图片
    private BufferedImage bkimg;
 
    //构造器初始化资源
    public GameBackGround(){
        bkimg = GameUtil.loadBufferedImage(Constant.BK_IMG_OATH);
    }
 
    //绘制图片
    public void draw(Graphics g){
 
        //填充背景色
        g.setColor(BK_COLOR);
        g.fillRect(0,0,FRAM_WIDTH,FRAM_HEIGNT);
        g.setColor(Color.black);
 
 
        //得到图片的高度和宽度
        int height = bkimg.getHeight();
        int weight = bkimg.getWidth();
        //循环的次数
        int count = Constant.FRAM_WIDTH/weight+1;
        for (int i = 0; i < count; i++) {
            g.drawImage(bkimg,weight*i,Constant.FRAM_HEIGNT-height,null);
        }
    }
}

 6、GameBarrierLayer(游戏中障碍物层)

在第87行中需要在电脑盘中创建一个txt文件,用来储存游戏数据,并在该文件中随意输入一位数字

package main;
 
 
import util.Constant;
 
import java.awt.*;
import java.io.*;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
 
 
/**
 * 游戏中障碍物层
 */
public class GameBarrierLayer {
 
    private GameTime gameTime;
 
    private int txt;
 
    private Random random = new Random();
 
    private List<Barrier> barriers;
 
    public GameBarrierLayer() {
        barriers = new ArrayList<>();
        gameTime = new GameTime();
    }
 
    //绘制障碍物
    public void draw(Graphics g, Bird bird) {
        for (int i = 0; i < barriers.size(); i++) {
            Barrier barrier = barriers.get(i);
 
            if (barrier.isVisible()) {
                barrier.draw(g);
            } else {
                Barrier remove = barriers.remove(i);
                Barrierpool.setPool(remove);
                i--;
            }
        }
        collideBird(bird);
        logic(g);
    }
 
    public void logic(Graphics g) {
        if (barriers.size() == 0) {
            ran();
            gameTime.begin();
            insert(600, 0, numberTop, 0);
            insert(600, 500 - numberDown, numberDown, 2);
        } else {
            long differ = gameTime.differ();
            g.setColor(Color.white);
            g.setFont(new Font("微软雅黑", 1, 20));
            g.drawString("坚持了:" + differ + "秒", 30, 50);
 
            //显示最高成绩
            txt = getTxt();
            if (differ <= txt){
                g.drawString("最高成绩:" + txt , 200, 50);
            }else {
                setTxt(String.valueOf(differ));
                g.drawString("最高成绩:" + getTxt() , 200, 50);
            }
 
            //判断最后一个障碍物是否完全进入屏幕内
            Barrier last = barriers.get(barriers.size() - 1);
            if (last.isInFrame()) {
                ran();
                if (number < 50){
                    insert(600,32,440,4);
                }else if (number>450){
                   insert(600,125,200,6);
                }else {
                    insert(600, 0, numberTop, 0);
                    insert(600, 500 - numberDown, numberDown, 2);
                }
 
            }
        }
    }
 
    //用于储存游戏数据
    File file = new File("E:\\小鸟.txt");
 
    /**
     * 从文件获取数据
     * @return
     */
    public int getTxt()   {
        BufferedReader in = null;
        try {
            in = new BufferedReader(new FileReader(file));
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
        int read = 0;
        try {
            read = Integer.parseInt(in.readLine());
        } catch (IOException e) {
            e.printStackTrace();
        }
        try {
            in.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return read;
    }
 
    /**
     * 写入数据到文件
     * @param str
     */
    public void setTxt(String str)   {
        FileWriter out = null;
        try {
            out = new FileWriter(file);
        } catch (IOException e) {
            e.printStackTrace();
        }
        try {
            out.write(str);
        } catch (IOException e) {
            e.printStackTrace();
        }
        try {
            out.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
 
 
    /**
     * 用于从池中获取对象,并吧参数封装成barrier 存入barriers数组中
     */
    public void insert(int x, int y, int num, int type) {
        Barrier top = Barrierpool.getPool();
        top.setX(x);
        top.setY(y);
        top.setHeight(num);
        top.setType(type);
        top.setVisible(true);
        barriers.add(top);
    }
 
 
    //上方障碍物高度
    private int numberTop;
    //下方障碍物高度
    private int numberDown;
    private int number;
 
    //产生两个100-500之间的随机高度
    public void ran() {
        numberTop = random.nextInt(400) + 100;
        numberDown = random.nextInt(400) + 100;
        number = random.nextInt(500);
        //如果管道重合,则重新随机
        if (numberTop + numberDown > 450) {
            ran();
        }
    }
 
    /**
     * 判断障碍物和小鸟发生碰撞
     */
    public boolean collideBird(Bird bird) {
        for (int i = 0; i < barriers.size(); i++) {
            Barrier barrier = barriers.get(i);
            //判断矩形是否相交
            if (barrier.getRect().intersects(bird.getRect())) {
                System.out.println("装上啦");
                bird.life = false;
            }
        }
        return false;
    }
 
/**
 * 用于清空障碍物的池子
 */
 public void restant(){
     barriers.clear();
 }
 
 
}

 

 7.GameFrame(游戏的主窗口类)

package main;
 
import static util.Constant.*;
 
import java.awt.*;
import java.awt.event.*;
import java.awt.image.BufferedImage;
 
/**
 * 游戏的主窗口类,所有的关于游戏中绘制的内容都在此类中完成。
 */
public class GameFrame extends Frame {
 
    //实例化gamebackGround类
    private GameBackGround gameBackGround;
 
    //实例化Bird类
    private Bird bird;
 
    //实例化GameBarrierLayer类
    private GameBarrierLayer gameBarrierLayer;
 
    //实例化GameFrontGround类
    private GameFrontGround gameFrontGround;
 
 
    //存放图片的图片
    private BufferedImage buffimg = new BufferedImage(FRAM_WIDTH,FRAM_HEIGNT,BufferedImage.TYPE_4BYTE_ABGR);
 
 
    //构造方法中初始化一些参数
    public GameFrame(){
        //窗口是否可见
        setVisible(true);
        //窗口的大小
        setSize(FRAM_WIDTH,FRAM_HEIGNT);
        //窗口的标题
        setTitle(FRAM_TITLE);
        //窗口的初始化位置
        setLocation(FRAM_X,FRAM_Y);
        //窗口的大小不可改变
        setResizable(false);
 
 
        //窗口的关闭事件
        addWindowListener(new WindowAdapter() {
            @Override
            public void windowClosing(WindowEvent e) {
                System.exit(0);//结束程序
            }
        });
 
 
        //初始化游戏对象
        initGamg();
 
        new run().start();
 
        //添加按键监听
        addKeyListener(new KeyAdapter() {
            @Override
            public void keyPressed(KeyEvent e) {
                add(e);
            }
 
            @Override
            public void keyReleased(KeyEvent e) {
                minu(e);
            }
        });
 
 
 
    }
 
    //对游戏中的对象初始化
    public void initGamg(){
        gameBackGround = new GameBackGround();
        bird = new Bird();
        gameFrontGround = new GameFrontGround();
        gameBarrierLayer = new GameBarrierLayer();
    }
 
 
 
    class run extends Thread{
        @Override
        public void run() {
            while (true) {
                repaint();
                try {
                    Thread.sleep(33);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }
 
 
    /**
     * 所有的我们需要绘制的内容都在此方法中进行调用绘制
     */
    @Override
    public void update(Graphics g) {
        if(bird.life){
            //得到图片的画笔
            Graphics graphics = buffimg.getGraphics();
 
            gameBackGround.draw(graphics);
            bird.draw(graphics);
            gameFrontGround.draw(graphics);
            gameBarrierLayer.draw(graphics,bird);
 
            //一次性的将图片绘制到屏幕中
            g.drawImage(buffimg,0,0,null);
        }else {
            String over = "游戏结束";
            g.setColor(Color.red);
            g.setFont(new Font("微软雅黑",1,60));
            g.drawString(over,180,250);
 
            String reset = "Space Reset Game";
            g.drawString(reset,25,350);
        }
    }
 
 
    //按键
    public void add(KeyEvent e){
        switch (e.getKeyCode()){
            case KeyEvent.VK_UP:
                bird.fly(1);
                break;
            case KeyEvent.VK_SPACE:
                if (bird.life == false) {
                    restart();
                }
                break;
        }
    }
 
 
 
    //抬键
    public void minu(KeyEvent e){
        switch (e.getKeyCode()){
            case KeyEvent.VK_UP:
                bird.fly(5);
                break;
        }
    }
 
    /**
     * 重置游戏
     */
    public void restart(){
        gameBarrierLayer.restant();
        bird.restartDraw();
    }
 
 
}

8、GameFrontGround(游戏的前景类)

package main;
 
import util.Constant;
import util.GameUtil;
 
import java.awt.*;
import java.awt.image.BufferedImage;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
 
/**
 * 游戏的前景类
 */
public class GameFrontGround {
    //云彩的个数
    private static final int CLOUND_COUNT = 2;
    //存放云彩的容器
    private List<Cloud> clouds;
    //云彩的飞行速度
    private static final int CLOUNG_SPEED = 1;
    //使用到图片资源
    private BufferedImage[] img;
 
    //用于产生随机数
    private Random random;
 
    // 构造器初始化数据
    public GameFrontGround() {
        clouds = new ArrayList<>();
        img = new BufferedImage[CLOUND_COUNT];
 
        //容器中添加云彩的图片
        for (int i = 0; i < CLOUND_COUNT; i++) {
            img[i] = GameUtil.loadBufferedImage("飞翔的小鸟/img/cloud0" + i + ".png");
        }
        random = new Random();
    }
 
    //绘制云彩
    public void draw(Graphics g) {
        logic();
        for (int i = 0; i < clouds.size(); i++) {
            clouds.get(i).draw(g);
        }
    }
 
    /**
     * 用于云彩的个数控制
     */
    private void logic() {
        if ((int) (500 * Math.random()) < 5) {
            Cloud cloud = new Cloud(img[random.nextInt(CLOUND_COUNT)], CLOUNG_SPEED, 600, random.nextInt(150));
            clouds.add(cloud);
        }
        for (int i = 0; i < clouds.size(); i++) {
            Cloud cloud = clouds.get(i);
            if (cloud.isOutFrame()){
                clouds.remove(i);
                i--;
                System.out.println("移除了"+cloud);
            }
        }
 
    }
}

 9、GameTime(游戏计时器)

package main;
 
/**
 * 游戏计时器
 */
public class GameTime {
 
//开始
    private long beginTime;
    //结束
    private long endTime;
    //时间差
    private long differ;
 
    public GameTime(){}
 
    public void  begin(){
        beginTime = System.currentTimeMillis();
    }
    public long differ(){
        endTime = System.currentTimeMillis();
        return differ=(endTime-beginTime)/1000;
    }
 
}

四、util包

1、Constant(设置窗口资源)

package util;
 
import java.awt.*;
 
/**
 * @author
 * @create
 */
public class Constant {
    //窗口的大小
    public static final int FRAM_WIDTH= 600;
    public static final int FRAM_HEIGNT= 500;
 
    //窗口标题
    public static final String FRAM_TITLE= "飞翔的小鸟";
 
    //窗口的初始化位置
    public static final int FRAM_X= 200;
    public static final int FRAM_Y= 200;
 
    //背景图片
    public static final String BK_IMG_OATH = "飞翔的小鸟/img/bird_bk.png";
 
    //背景色
    public static final Color BK_COLOR = new Color(0x4BC4CF);
 
    //小鸟图片资源
    public static final String[] BIRD_IMG={
            "飞翔的小鸟/img/bird_normal.png","飞翔的小鸟/img/bird_up.png","飞翔的小鸟/img/bird_down.png"
    };
 
    //障碍物图片资源
    public static final String[] BARRIER_IMG_PATH ={
            "飞翔的小鸟/img/barrier.png","飞翔的小鸟/img/barrier_up.png","飞翔的小鸟/img/Barrier_down.png"};
}

 2、GameUtil(游戏工具类)

package util;
 
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.FileInputStream;
import java.io.IOException;
 
/**
 * 游戏工具类
 */
public class GameUtil {
    /**
     *该方法传入一个图片路径 读取图片
     */
    public static BufferedImage loadBufferedImage(String ImgPath){
        try {
            return ImageIO.read(new FileInputStream(ImgPath));
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1243178.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python基础:生成器(Generators)和生成器表达式(Generator Expressions)详解

生成器&#xff08;Generators&#xff09;和 生成器表达式&#xff08;Generator Expressions&#xff09;是 Python 中用于处理迭代器和序列数据的强大工具。它们允许你按需生成值&#xff0c;而不是一次性生成所有值&#xff0c;从而节省内存和提高性能。 1. 生成器&#x…

前缀和——724. 寻找数组的中心下标

文章目录 &#x1f353;1. 题目&#x1fad2;2. 算法原理&#x1f984;解法一&#xff1a;暴力枚举&#x1f984;解法二&#xff1a;前缀和 &#x1f954;3. 代码实现 &#x1f353;1. 题目 题目链接&#xff1a;724. 寻找数组的中心下标 - 力扣&#xff08;LeetCode&#xff0…

【一文搞定】在Docker中搭建centos7远程桌面环境(Xfce、Gnome两种方式)

目录 前言一、基于GNOME构建远程桌面二、基于Xfce构建远程桌面&#xff08;轻量级&#xff09; 前言 本文提供两种安装方式&#xff0c;均自己测试过&#xff0c;最后还是选择了Xfce&#xff0c;因为它比较轻量级&#xff0c;占用资源较少。大家也可以都试试&#xff0c;比较感…

idea 26 个天花板技巧

1、 查看代码历史版本&#xff1b;2、 调整idea的虚拟内存&#xff1a;&#xff1b;3、 idea设置成eclipse的快捷键&#xff1b;4、 设置提示词忽略大小写&#xff1b;5、 关闭代码检查&#xff1b;6、 设置文档注释模板&#xff1b;7、 显示方法分隔符&#xff1b;8、 设置多行…

【大神支招】3步,打造一张BI报表

随着BI报表的高效直观、灵活分析的特点越来越被大家所熟知&#xff0c;很多BI零基础的用户可积极尝试制作BI报表&#xff0c;以达到灵活自助分析、高效智能分析的效果。那么BI报表零基础的小白们该怎么做BI报表&#xff0c;才能又快又好地做出来&#xff1f; 大神支招&#xf…

Authing 入选《 2023 年央国企信创应用与实践研究报告》优秀服务商

11 月 21 日&#xff0c;Authing 身份云作为国内唯一事件驱动云原生身份平台入选《 2023 年央国企信创应用与实践研究报告》优秀服务商&#xff0c;该报告由第一新声研究院合伙人、Gartner 前高管合伙人/副总裁李长华牵头指导&#xff0c;第一新声创始人兼 CEO 组织&#xff0c…

畅捷通T6 客户端登录提示 运行时错误 372 加载控件cfloatmenu失败

客户单win10电脑, T6版本是 V7.1 不知道操作了什么每个电脑提示 运行时错误372: 从加载控件CFloatMenu失败。您的版本可能已过期。确认您使用的控件版本是同您的应用程序一起提供的。 ******* 解决办法: 找个其他电脑复制mscomctl.ocx 到操作系统目录里面注册一下,即可. …

蓝桥杯物联网竞赛_STM32L071_2_继电器控制

CubeMX配置&#xff1a; Function.c及Function.h&#xff1a; #include "Function.h" #include "gpio.h" void Function_LD5_ON(void){HAL_GPIO_WritePin(LD5_GPIO_Port, LD5_Pin, GPIO_PIN_RESET); }void Function_LD5_OFF(void){HAL_GPIO_WritePin(LD5_…

【Unity】 UGUI的PhysicsRaycaster (物理射线检测)组件的介绍及使用

1. 什么是PhysicsRaycaster组件&#xff1f; PhysicsRaycaster是Unity UGUI中的一个组件&#xff0c;用于在UI元素上进行物理射线检测。它可以检测鼠标或触摸事件是否发生在UI元素上&#xff0c;并将事件传递给相应的UI元素。 2. PhysicsRaycaster的工作原理 PhysicsRaycast…

便携式心电图机方案_基于MT6735平台的手持心电图机

便携式心电图机具备体积小、易携带、兼容12导模式的特点&#xff0c;通过工频滤波、基线滤波和肌电滤波等处理&#xff0c;能够获得更精准的心电图谱。该设备可以与医院信息系统(HIS)相连接&#xff0c;实现患者信息的共享。采集的心电数据可以通过无线方式发送到心电判读平台&…

Python函数式编程:让你的代码更优雅更简洁

概要 函数式编程&#xff08;Functional Programming&#xff09;是一种编程范式&#xff0c;它将计算视为函数的求值&#xff0c;并且避免使用可变状态和循环。 函数式编程强调的是函数的计算&#xff0c;而不是它的副作用。 在函数式编程中&#xff0c;函数是第一类公民&a…

postgresql数据库中update使用的坑

简介 在数据库中进行增删改查比较常见&#xff0c;经常会用到update的使用。但是在近期发现update在oracle和postgresql使用却有一些隐形区别&#xff0c;oracle 在执行update语句的时候set 后面必须跟着1对1的数据关联而postgresql数据库却可以一对多&#xff0c;这就导致数据…

springboot使用redis缓存乱码(key或者 value 乱码)一招解决

如果查看redis中的值是这样 创建一个配置类就可以解决 package com.deka.config;import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; i…

2024年的云趋势:云计算的前景如何?

本文讨论了2024年云计算的发展趋势。 适应复杂的生态系统、提供实时功能、优先考虑安全性和确保可持续性的需求正在引领云计算之船。多样化的工作负载允许探索通用的公共云基础设施范例之外的选项。由于需要降低成本、提高灵活性和降低风险&#xff0c;混合云和多云系统越来越受…

C++中的map和set的使用

C中的map详解 关联式容器键值对树形结构的关联式容器set的使用1. set的模板参数列表2. set的构造3. set的迭代器4. set的容量5. set修改操作6. set的使用举例 map1. map的简介2. map的模板参数说明3. map的构造4. map的迭代器5. map的容量与元素访问6. map的元素修改 multimap和…

机器学习之危险品车辆目标检测

危险品的运输涉及从离开仓库到由车辆运输到目的地的风险。监控事故、车辆运动动态以及车辆通过特定区域的频率对于监督车辆运输危险品的过程至关重要。 在线工具推荐&#xff1a; 三维数字孪生场景工具 - GLTF/GLB在线编辑器 - Three.js AI自动纹理化开发 - YOLO 虚幻合成数…

js实现获取原生form表单的数据序列化表单以及将数组转化为一个对象obj,将数组中的内容作为对象的key转化为对象,对应的值转换为对象对应的值

1.需求场景 哈喽 大家好啊&#xff0c;今天遇到一个场景&#xff0c; js实现获取原生form表单的数据序列化表单以及将数组转化为一个对象obj&#xff0c;将数组中的内容作为对象的key转化为对象&#xff0c;对应的值转换为对象对应的值 数组对象中某个属性的值&#xff0c;转…

开店必看!又有新变化?一文读懂2024亚马逊卖家入驻要求和流程

亚马逊2024年新卖家入驻正在火热进行中&#xff0c;想加入亚马逊卖家行列的小伙伴们准备好了吗&#xff1f;9月20日&#xff0c;亚马逊官方宣布2024年新卖家入驻正式开启&#xff0c;又一年招商季来临&#xff0c;东哥还了解到2024年亚马逊卖家注册要求有了一点新变化&#xff…

白银现货怎么开户,需要投入多少钱?

在白银投资市场中&#xff0c;有一种交易产品种类&#xff0c;它能够提供给人们稳定的理财环境&#xff0c;还具有辨别的交易环境。这种白银理财产品就是现货白银&#xff0c;也有一部分投资者将其称为白银现货。为了人们对这一产品具有更加清晰的认识&#xff0c;今天万洲金业…