2013-07-24 3 views
-5

Ну, я пытался решить эту проблему, но я не могу, если кто-то может мне помочь ...Несоответствие типа: не удается преобразовать из междунар в булево

КОД:

package com.skybox.runordie; 

import java.awt.BorderLayout; 
import java.awt.Canvas; 
import java.awt.Color; 
import java.awt.Dimension; 
import java.awt.Graphics; 
import java.awt.image.BufferStrategy; 
import java.awt.image.BufferedImage; 
import java.awt.image.DataBufferInt; 

import javax.swing.JFrame; 

public class Game extends Canvas implements Runnable { 

    public static final long serialVersionUID = 1L; 

    public static final int WIDTH = 160; 
    public static final int HEIGHT = WIDTH/12 * 9; 
    public static final int SCALE = 3; 
    public static final String NAME = "Run Or Die"; 

    private JFrame frame; 

    public boolean running = false; 
    public int tickCount = 0; 

    private BufferedImage image = new BufferedImage(WIDTH,HEIGHT,BufferedImage.TYPE_INT_RGB); 
    private int[] pixels = ((DataBufferInt) image.getRaster().getDataBuffer()).getData(); 


    public Game() { 
    setMinimumSize(new Dimension(WIDTH * SCALE, HEIGHT * SCALE)); 
    setMaximumSize(new Dimension(WIDTH * SCALE, HEIGHT * SCALE)); 
    setPreferredSize(new Dimension(WIDTH * SCALE, HEIGHT * SCALE)); 

    frame = new JFrame(NAME); 

    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
    frame.setLayout(new BorderLayout()); 

    frame.add(this, BorderLayout.CENTER); 
    frame.pack(); 

    frame.setResizable(false); 
    frame.setLocationRelativeTo(null); 
    frame.setVisible(true); 
    } 


    public synchronized void start() { 
    running = true; 
    new Thread(this).start(); 
    } 

    public synchronized void stop() { 
    running = false; 
    } 

    public void run() { 
    long lastTime = System.nanoTime(); 
    double nsPerTick = 1000000000D/60D; 

    int ticks = 0; 
    int frames = 0; 

    long lastTimer = System.currentTimeMillis(); 
    double delta = 0; 

    while(running) { 
     long now = System.nanoTime(); 
     delta += (now - lastTime)/nsPerTick; 
     lastTime = now; 
     boolean shouldRender = true; 

     while (delta >= 1) { 
     ticks++; 
     tick(); 
     delta -= 1; 
     shouldRender = true; 
     } 
     try { 
     Thread.sleep(2); 
     } catch (InterruptedException e) { 
     e.printStackTrace(); 
     } 
     if (shouldRender) { 
     frames++; 
     render(); 
     } 
     if(System.currentTimeMillis() - lastTimer > 1000) { 
     lastTimer += 1000; 
     System.out.println(frames + " frames," + ticks + " ticks."); 
     frames = 0; 
     ticks = 0; 
     } 
    } 
    } 

    public void tick() { 
    tickCount++; 
    for(int i = 0; pixels.length; i++) { 
     pixels[i] = i + tickCount; 
    } 
} 

    public void render() { 
    BufferStrategy bs = getBufferStrategy(); 
    if(bs == null) { 
     createBufferStrategy(3); 
     return; 
    } 

    Graphics g = bs.getDrawGraphics(); 
    g.drawImage(image, 0, 0, getWidth(), getHeight(), null); 
    g.setColor(Color.BLACK); 
    g.fillRect(0, 0, getWidth(), getHeight()); 

    g.dispose(); 
    bs.show(); 
    } 

    public static void main(String[] args) { 
    new Game().start(); 
    } 


    public int[] getPixels() { 
    return pixels; 
    } 


    public void setPixels(int[] pixels) { 
    this.pixels = pixels; 
    } 

} 
+2

Начать свой код здесь, и добавить язык тегов. И скажите нам, какая строка кода вызывает проблему. –

+0

Пожалуйста, укажите * соответствующий * код здесь ... –

+0

Слишком много кода для вопроса, особенно без номера строки или дополнительной информации. – jbabey

ответ

5

На что вы получаете ошибку? Если бы я был догадаться, это прямо здесь:

for(int i = 0; pixels.length; i++) { 
    pixels[i] = i + tickCount; 
} 

Второй пункт в for заявлении должно быть постоянным условием цикла, который представляет собой логическое. Однако pixels.length не является логическим, это целое число. Я предполагаю, что ваша цель состоит, чтобы сравнить это число с другим целого числа, в результате чего логического значения:

for(int i = 0; i < pixels.length; i++) { 
    pixels[i] = i + tickCount; 
} 

Просто поставляю целый сам по себе не говорит рамочное ничего о продолжающемся состоянии. Он должен знать, в каком состоянии продолжить цикл (иначе цикл должен завершиться). Это условие, в этом случае, когда i составляет менее pixels.length.

+0

Это должно появиться прямо на IDE ... то есть, если OP использует его. Тем не менее, хорошо поймать. – Gamb

+0

@ Gamb Все ошибки сборки должны появляться на любой хорошей IDE ... – MathSquared

+0

@ Gamb, и др. Даже без IDE сам компилятор будет указывать ошибку и строку, на которой найдена ошибка. – David

0

Проблема заключается в следующем методе

public void tick() { 

      tickCount++; 

      for(int i = 0; pixels.length; i++) { // should compare pixels.length to some int to get boolean return 

        pixels[i] = i + tickCount; 

      }