2017-03-28 25 views
2

希望我可以得到一些建议。回到主要活动在Android应用程序后退键看到用户得分

我的程序有一个精灵,当点击/点击时,屏幕上会显示一个分数。当游戏结束(时间用完)时,我希望用户能够按下手机上的后退键返回到开始游戏的主/开始屏幕/活动,但它也会显示他们的分数(多少点击)。

我正在努力弄清楚如何让它回到后面的按键。如果需要,我可以在以后的日期找出高分位。我只想回到那个开始屏幕。

UPDATE:

我认为它可能有一些与我的表现做,为什么它不工作。我试图将'GameView'类添加到清单,但它不会接受它。它说它没有默认的构造函数。有任何想法吗?

<application 
    android:allowBackup="true" 
    android:icon="@drawable/ic_launcher" 
    android:label="@string/app_name" 
    android:theme="@style/AppTheme" > 
    <activity 
     android:name="cct.mad.lab.MainMenu" 
     android:label="@string/app_name" > 
     <intent-filter> 
      <action android:name="android.intent.action.MAIN" /> 

      <category android:name="android.intent.category.LAUNCHER" /> 
     </intent-filter> 
    </activity> 
    <activity 
     android:name=".GameActivity" 
     android:label="@string/app_name" > 
    </activity> 
    <activity 
     android:name=".GameView" 
     android:label="@string/app_name" > 
    </activity> 

我GameView代码如下:

public class GameView extends SurfaceView implements SurfaceHolder.Callback { 

/* Member (state) fields */ 
private GameLoopThread gameLoopThread; 
private Paint paint; //Reference a paint object 
/** The drawable to use as the background of the animation canvas */ 
private Bitmap mBackgroundImage; 
// For creating the game Sprite 
private Sprite sprite; 
// For recording the number of hits 
private int hitCount; 
// To track if a game is over 
private boolean gameOver; 
// To play sound 
private SoundPlayer sound; 

//int backButtonCount = 0; 

public GameView(Context context) { 
    super(context); 
    // Focus must be on GameView so that events can be handled. 
    this.setFocusable(true); 
    // For intercepting events on the surface. 
    this.getHolder().addCallback(this); 
    // Background image added 
    mBackgroundImage = BitmapFactory.decodeResource(this.getResources(), R.drawable.half_moon); 

    //sound = new SoundPlayer(this); 

} 
/* Called immediately after the surface created */ 
public void surfaceCreated(SurfaceHolder holder) { 
    // We can now safely setup the game start the game loop. 
    ResetGame();//Set up a new game up - could be called by a 'play again option' 
    mBackgroundImage = Bitmap.createScaledBitmap(mBackgroundImage, getWidth(), getHeight(), true); 
    gameLoopThread = new GameLoopThread(this.getHolder(), this); 
    gameLoopThread.running = true; 
    gameLoopThread.start(); 
} 



// For the countdown timer 
private long startTime; // Timer to count down from 
private final long interval = 1 * 1000; // 1 sec interval 
private CountDownTimer countDownTimer; // Reference to the class 
private boolean timerRunning = false; 
private String displayTime; // To display the time on the screen 


//To initialise/reset game 
private void ResetGame(){ 
    /* Set paint details */ 
    paint = new Paint(); 
    paint.setColor(Color.WHITE); 
    paint.setTextSize(20); 
    sprite = new Sprite(this); 
    hitCount = 0; 
    // Set timer 
    startTime = 10; // Start at 10s to count down 
    // Create new object - convert startTime to milliseconds 
    countDownTimer = new MyCountDownTimer(startTime*1000, interval); 
    countDownTimer.start(); // Start the time running 
    timerRunning = true; 
    gameOver = false; 


} 

// Countdown Timer - private class 
private class MyCountDownTimer extends CountDownTimer { 

    public MyCountDownTimer (long startTime, long interval) { 
     super(startTime, interval); 
    } 
    public void onFinish() { 
     //displayTime = "Time is up!"; 
     timerRunning = false; 
     countDownTimer.cancel(); 
     gameOver = true; 
    } 
    public void onTick (long millisUntilFinished) { 
     displayTime = " " + millisUntilFinished/1000; 
    } 
} 


//This class updates and manages the assets prior to drawing - called from the Thread 
public void update(){ 

    sprite.update(); 

} 
/** 
* To draw the game to the screen 
* This is called from Thread, so synchronisation can be done 
*/ 
public void doDraw(Canvas canvas) { 
    //Draw all the objects on the canvas 
    canvas.drawBitmap(mBackgroundImage, 0, 0, null); 

    if (!gameOver) { 
     sprite.draw(canvas); 
     canvas.drawText("Time Remaining: " + displayTime, 35, 50, paint); 
     canvas.drawText("Number of hits: " + hitCount, 250, 50, paint); 
    } else 
     canvas.drawText("Game Over!", 185, 100, paint); 
     canvas.drawText("To go back to the main menu, press the 'back' key", 15, 150, paint); 


} 

//To be used if we need to find where screen was touched 
public boolean onTouchEvent(MotionEvent event) { 
     if (sprite.wasItTouched(event.getX(), event.getY())) { 
      // This just renews the sprite for now 
      sprite = new Sprite(this); 
      //sound.playZapSound(); 
      hitCount++; 

     } 
    return true; 
} 

public void surfaceDestroyed(SurfaceHolder holder) { 
    gameLoopThread.running = false; 

    // Shut down the game loop thread cleanly. 
    boolean retry = true; 
    while(retry) { 
     try { 
      gameLoopThread.join(); 
      retry = false; 
     } catch (InterruptedException e) {} 
    } 
} 

public void getHitCount() { 



} 

public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) { 

} 

} 

我的MainActivity低于:

public class MainMenu extends Activity { 

private static final int SCORE_REQUEST_CODE = 1;// The request code for the intent 

TextView tvScore; 
String score; 
Intent gameIntent; 

protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.game_start); 
} 

public void startGame(View v){ 
    gameIntent = new Intent(this,GameActivity.class); 
    startActivityForResult(gameIntent, SCORE_REQUEST_CODE); 
} 
/* Create Options Menu */ 
public boolean onCreateOptionsMenu(Menu menu) { 
    // Inflate the menu; this adds items to the action bar if it is present. 
    getMenuInflater().inflate(R.menu.main_menu, menu); 
    return true; 
} 

// Respond to item selected on OPTIONS MENU 
public boolean onOptionsItemSelected(MenuItem item) { 
    // Handle item selection 
    switch (item.getItemId()) { 
    //put data in Intent 
    case R.id.easy: 
     Toast.makeText(this, "Easy chosen", Toast.LENGTH_SHORT).show(); 
     return true; 
    case R.id.medium: 
     Toast.makeText(this, "Medium chosen", Toast.LENGTH_SHORT).show(); 
     return true; 
    case R.id.hard: 
     Toast.makeText(this, "Hard chosen", Toast.LENGTH_SHORT).show(); 
     return true; 
    case R.id.other: 
     Toast.makeText(this, "Other chosen", Toast.LENGTH_SHORT).show(); 
     return true; 
    default: 
     return super.onOptionsItemSelected(item); 
    } 
} 

protected void onActivityResult(int requestCode, int resultCode, Intent retIntent) { 
    // Check which request we're responding to 
    if (requestCode == SCORE_REQUEST_CODE) { 
     // Make sure the request was successful 
     if (resultCode == RESULT_OK) { 
      if (retIntent.hasExtra("GAME_SCORE")) { 
       int scoreFromGame = retIntent.getExtras().getInt("GAME_SCORE"); 
       tvScore.setText(Integer.toString(scoreFromGame)); 
      } 
     } 
    } 

} 


} 

与往常一样,任何帮助,不胜感激。

谢谢

+0

尝试重写onBackPressed()的活动,并启动活动的意图,可能会提供您所期望的效果的帮助,也评论onBackPressed() –

回答

0

使用onBackPressed。

@Override 
public void onBackPressed() { 
    Intent i= new Intent(your_present_activity.this,the_activity_you_want_to_jump_to.class); 
    startActivity(i); 
    finish(); 
} 

您可以使用newintent.putExtra(name,“key”)将您的分数记录到Main.class中;

+0

super.onBackPressed()有什么地方特别是我应该把这个因为覆盖会出现错误 - “方法不会覆盖超类中的方法” –

+0

调用super.onBackPressed();不要删除@override。 – qwerty421

+0

添加,给出了错误 - '无法解析方法'onBackPressed()'' –

0

看来我的后退按钮不起作用的问题全部归结于doDraw方法中的其他语句,而没有在两个语句中使用花括号。添加这些,它工作正常。当按下后退按钮时,会自动调用surfaceDestroyed方法,因为这会停止gameLoopThread类。

感谢大家试图帮助我。

相关问题