gpt4 book ai didi

Java:加快我的代码速度

转载 作者:行者123 更新时间:2023-12-01 17:32:27 25 4
gpt4 key购买 nike

我一直在编写一个渲染图 block 和 GUI 等的应用程序。我似乎遇到了一个问题,我的 PaintComponent 似乎占用了太多 CPU,并且无法再在我的小型计算机上以高于 10 FPS 的速度运行。我想知道是否有更有效的方法来运行此代码或对其进行线程处理或任何其他方法来提高计算速度。这是我的代码:

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import javax.swing.JPanel;

@SuppressWarnings("serial")
public class M1 extends JPanel implements Runnable {
public static double zoom = 1.25;
public static double charZoom = 1;
public static boolean breaking = false;

public void run() {

}

public void paintComponent(Graphics g) {
super.paintComponent(g);
if(zoom <= 0.03) zoom = 1.25;

for(int cy = 0; cy < 3; cy++) {
for(int cx = 0; cx < 3; cx++) {
for(int y = 0; y < 16; y++) {
for(int x = 0; x < 16; x++) {
g.drawImage(Tiles.tileImages.get(C0.chunk[x][y][cx][cy]),
(int)((C0.cX[cx][cy] * C0.chunkWidth) * zoom) + ((int)(32 * zoom) * x) +
((M0.gameFrame.getWidth() / 2)) - (int)(PEntity.x.getValue() * zoom),
(int)((C0.cY[cx][cy] * C0.chunkHeight) * zoom) + ((int)(32 * zoom) * y) +
((M0.gameFrame.getHeight() / 2)) - (int)(PEntity.y.getValue() * zoom) + (int)(24.25 * zoom),// <-- 24.25 used to correctly position charatcter
(int)(32 * zoom), (int)(32 * zoom), this);
if(C0.chunk[x][y][cx][cy].equals("a05")) {
g.drawImage(Tiles.treetop,
(int)((C0.cX[cx][cy] * C0.chunkWidth) * zoom) + ((int)(32 * zoom) * x) +
((M0.gameFrame.getWidth() / 2)) - (int)(PEntity.x.getValue() * zoom),
(int)((C0.cY[cx][cy] * C0.chunkHeight) * zoom) + ((int)(32 * zoom) * y) +
((M0.gameFrame.getHeight() / 2)) - (int)(PEntity.y.getValue() * zoom) + (int)(24.25 * zoom)
- (int) (32 * zoom),// <-- 24.25 used to correctly position charatcter
(int)(32 * zoom), (int)(32 * zoom), this);
}
}
}
}
}

if(breaking) {
g.drawImage(M3.currentBreak, (int)((C0.cX[M3.cx][M3.cy] * C0.chunkWidth) * zoom) + ((int)(32 * zoom) * M3.x) +
((M0.gameFrame.getWidth() / 2)) - (int)(PEntity.x.getValue() * zoom),
(int)((C0.cY[M3.cx][M3.cy] * C0.chunkHeight) * zoom) + ((int)(32 * zoom) * M3.y) +
((M0.gameFrame.getHeight() / 2)) - (int)(PEntity.y.getValue() * zoom) + (int)(24.25 * zoom),
(int)(32 * zoom), (int)(32 * zoom), this);
}

M3.placeX = (48 * zoom);
M3.placeY = (48 * zoom);

if(M0.HUDenabled) {
g.drawImage(PEntity.currentChar,
(M0.gameFrame.getWidth() / 2) - (int)((16 * charZoom) * zoom),
(M0.gameFrame.getHeight() / 2) - (int)((32 * charZoom) * zoom),
(int)((32 * charZoom) * zoom), (int)((64 * charZoom) * zoom), this);

g.setColor(Color.BLACK);
g.setFont(new Font("Dialog", 1, 12));
g.drawString("Terrem" + " By Tyler D :)", 5, 15);
g.drawString("X: " + PEntity.x.getValue(), 5, 28);
g.drawString("Y: " + PEntity.y.getValue(), 5, 41);
g.drawString("ChunkX: " + C0.currentChunkX.getValue(), 5, 54);
g.drawString("ChunkY: " + C0.currentChunkY.getValue(), 5, 67);
g.drawString("BlockX: " + C0.currentBlockX.getValue(), 5, 80);
g.drawString("BlockY: " + C0.currentBlockY.getValue(), 5, 93);
g.drawString("Zoom: " + zoom, 5, 106);
g.drawString(M4.tileArea[0][0] + "_" + M4.tileArea[1][0] + "_" + M4.tileArea[2][0], 5, 126);
g.drawString(M4.tileArea[0][1] + "_" + M4.tileArea[1][1] + "_" + M4.tileArea[2][1], 5, 139);
g.drawString(M4.tileArea[0][2] + "_" + M4.tileArea[1][2] + "_" + M4.tileArea[2][2], 5, 152);
g.drawString("FPS: " + (int) FPS.currentFPS, 5, 172);

//GUI
g.drawImage(M0.GUIbar, (M0.gameFrame.getWidth() - (624)) / 2, (M0.gameFrame.getHeight() - 80), 624, 40, this);
for(int i = 0; i < 9; i++) {
g.drawImage(Item.Item_Img.get(PEntity.PInv[i]), ((M0.gameFrame.getWidth() - (624)) / 2) + 6 + (36 * i),
(M0.gameFrame.getHeight() - 74), 28, 28, this);
if(Item.Item_Img.get(PEntity.PInv[i]) != null) {
g.drawString("" + (PEntity.stk[i] + 1), ((M0.gameFrame.getWidth() - (624)) / 2) + 6 + (36 * i),
(M0.gameFrame.getHeight() - 47));
}
}
}

repaint();
FPS.calculateFrameRate();
}

public M1() {
M0.gameFrame.setVisible(true);
Clock.Start();
setBackground(new Color(242, 220, 121));
System.out.println("M1 loaded...");
}
}

此外,我还可以看出,这是一个大循环,导致此时大约 200 FPS 消失,因为我评论了该部分,然后我的 FPS 飙升至大约 250。

最佳答案

如果您使用的 Graphics2D 实例是线程安全的,您似乎可以在方法顶部对一些外部 for 循环进行多线程处理。为此保留一个 ThreadPoolExecutor 可能是值得的,然后将外部 for 循环分解为 Runnable 实例。这完全取决于抽奖顺序对您是否重要 - 仅从您发布的代码很难判断。

另一件事让我惊讶的是你如何访问你的 4-D 图像数组。回想一下,多维 Java 数组实际上是对其他数组的引用的数组。您可能最好在每个循环的顶部获取对特定子数组的引用,并访问已保存的子数组引用,而不是直接索引原始数组。这将为您节省大量不必要的内存获取。

关于Java:加快我的代码速度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9692838/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com