Redesigned the Continue Game Screen. Also the list is now sorted and only the top 10 recent played games are saved. All the others are deleted.
This commit is contained in:
parent
7d2ec4abae
commit
e2ecfe9292
6 changed files with 161 additions and 21 deletions
|
@ -141,7 +141,7 @@ public class GameController implements IModelChangedListener {
|
|||
boolean[][] setNotes = gic.getSetNotes();
|
||||
this.gameID = gic.getID();
|
||||
this.difficulty = gic.getDifficulty();
|
||||
this.time = gic.getTime();
|
||||
this.time = gic.getTimePlayed();
|
||||
|
||||
setGameType(gic.getGameType());
|
||||
this.gameBoard = new GameBoard(gic.getGameType());
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
package tu_darmstadt.sudoku.controller;
|
||||
|
||||
import android.os.*;
|
||||
import android.util.Log;
|
||||
|
||||
import java.util.LinkedList;
|
||||
|
|
|
@ -24,6 +24,7 @@ public class SaveLoadGameStateController {
|
|||
private static String FILE_EXTENSION = ".txt";
|
||||
private static String SAVE_PREFIX = "save_";
|
||||
private static String SAVES_DIR = "saves";
|
||||
private static final int MAX_NUM_OF_SAVED_GAMES = 10;
|
||||
|
||||
private static List<GameInfoContainer> list = new LinkedList<>();
|
||||
|
||||
|
@ -42,7 +43,7 @@ public class SaveLoadGameStateController {
|
|||
}
|
||||
File dir = context.getDir(SAVES_DIR, 0);
|
||||
|
||||
List<GameInfoContainer> result = new LinkedList<>();
|
||||
LinkedList<GameInfoContainer> result = new LinkedList<>();
|
||||
|
||||
// go through every file
|
||||
for(File file : dir.listFiles()) {
|
||||
|
@ -98,7 +99,75 @@ public class SaveLoadGameStateController {
|
|||
editor.putBoolean("savesChanged", false);
|
||||
editor.commit();
|
||||
|
||||
list = result;
|
||||
list = sortListByLastPlayedDate(result);
|
||||
|
||||
LinkedList<GameInfoContainer> removeList = new LinkedList<>();
|
||||
|
||||
for(int i = 0; i < list.size(); i++) {
|
||||
if(i >= MAX_NUM_OF_SAVED_GAMES) {
|
||||
deleteGameStateFile(list.get(i));
|
||||
removeList.add(list.get(i));
|
||||
}
|
||||
}
|
||||
|
||||
for(GameInfoContainer gic : removeList) {
|
||||
list.remove(gic);
|
||||
}
|
||||
|
||||
return list;
|
||||
}
|
||||
|
||||
private void deleteGameStateFile(GameInfoContainer gic) {
|
||||
File dir = context.getDir(SAVES_DIR, 0);
|
||||
|
||||
File file = new File(dir, SAVE_PREFIX+gic.getID()+FILE_EXTENSION);
|
||||
|
||||
file.delete();
|
||||
}
|
||||
|
||||
public LinkedList<GameInfoContainer> sortListByLastPlayedDate(LinkedList<GameInfoContainer> list) {
|
||||
|
||||
if(list.size() < 2) {
|
||||
return list;
|
||||
}
|
||||
|
||||
LinkedList<GameInfoContainer> listL = new LinkedList<>();
|
||||
LinkedList<GameInfoContainer> listR = new LinkedList<>();
|
||||
|
||||
int middle = list.size()/2;
|
||||
|
||||
for(int i = 0; i < list.size(); i++) {
|
||||
if(i < middle) {
|
||||
listL.add(list.get(i));
|
||||
} else {
|
||||
listR.add(list.get(i));
|
||||
}
|
||||
}
|
||||
|
||||
listL = sortListByLastPlayedDate(listL);
|
||||
listR = sortListByLastPlayedDate(listR);
|
||||
|
||||
return sortListByLastPlayedDateMerge(listL, listR);
|
||||
}
|
||||
|
||||
public LinkedList<GameInfoContainer> sortListByLastPlayedDateMerge(LinkedList<GameInfoContainer> list1, LinkedList<GameInfoContainer> list2) {
|
||||
|
||||
LinkedList<GameInfoContainer> result = new LinkedList<>();
|
||||
|
||||
while(!(list1.isEmpty() && list2.isEmpty())) {
|
||||
GameInfoContainer gic1 = list1.peek();
|
||||
GameInfoContainer gic2 = list2.peek();
|
||||
if(gic1 == null) {
|
||||
result.add(list2.pop());
|
||||
} else if(gic2 == null) {
|
||||
result.add(list1.pop());
|
||||
} else if(gic1.getLastTimePlayed().after(gic2.getLastTimePlayed())) {
|
||||
result.add(list1.pop());
|
||||
} else {
|
||||
result.add(list2.pop());
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
|
|
|
@ -51,10 +51,14 @@ public class GameInfoContainer {
|
|||
}
|
||||
}
|
||||
|
||||
public int getTime() {
|
||||
public int getTimePlayed() {
|
||||
return timePlayed;
|
||||
}
|
||||
|
||||
public Date getLastTimePlayed() {
|
||||
return lastTimePlayed;
|
||||
}
|
||||
|
||||
public void parseTime(String s) {
|
||||
try {
|
||||
this.timePlayed = Integer.valueOf(s);
|
||||
|
|
|
@ -13,12 +13,19 @@ import android.widget.AdapterView;
|
|||
import android.widget.BaseAdapter;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.ListView;
|
||||
import android.widget.RatingBar;
|
||||
import android.widget.TextView;
|
||||
|
||||
import java.text.DateFormat;
|
||||
import java.text.FieldPosition;
|
||||
import java.text.ParsePosition;
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
import java.util.TimeZone;
|
||||
|
||||
import tu_darmstadt.sudoku.controller.SaveLoadGameStateController;
|
||||
import tu_darmstadt.sudoku.controller.helper.GameInfoContainer;
|
||||
import tu_darmstadt.sudoku.game.GameDifficulty;
|
||||
import tu_darmstadt.sudoku.ui.view.R;
|
||||
|
||||
public class LoadGameActivity extends AppCompatActivity {
|
||||
|
@ -98,8 +105,11 @@ public class LoadGameActivity extends AppCompatActivity {
|
|||
|
||||
GameInfoContainer gic = loadableGameList.get(position);
|
||||
|
||||
TextView name = (TextView)convertView.findViewById(R.id.loadgame_listentry_gametype);
|
||||
TextView summary=(TextView)convertView.findViewById(R.id.loadgame_listentry_id);
|
||||
TextView gameType = (TextView)convertView.findViewById(R.id.loadgame_listentry_gametype);
|
||||
TextView difficulty =(TextView)convertView.findViewById(R.id.loadgame_listentry_difficultytext);
|
||||
RatingBar difficultyBar =(RatingBar)convertView.findViewById(R.id.loadgame_listentry_difficultybar);
|
||||
TextView playedTime = (TextView)convertView.findViewById(R.id.loadgame_listentry_timeplayed);
|
||||
TextView lastTimePlayed = (TextView)convertView.findViewById(R.id.loadgame_listentry_lasttimeplayed);
|
||||
ImageView image = (ImageView)convertView.findViewById(R.id.loadgame_listentry_gametypeimage);
|
||||
|
||||
switch(gic.getGameType()) {
|
||||
|
@ -115,8 +125,26 @@ public class LoadGameActivity extends AppCompatActivity {
|
|||
default:
|
||||
image.setImageResource(R.drawable.icon_default_9x9);
|
||||
}
|
||||
name.setText(gic.getGameType().name());
|
||||
summary.setText(String.valueOf(gic.getID()));
|
||||
gameType.setText(gic.getGameType().getStringResID());
|
||||
difficulty.setText(gic.getDifficulty().getStringResID());
|
||||
difficultyBar.setRating(GameDifficulty.getValidDifficultyList().indexOf(gic.getDifficulty())+1);
|
||||
|
||||
int time = gic.getTimePlayed();
|
||||
int seconds = time % 60;
|
||||
int minutes = ((time -seconds)/60)%60 ;
|
||||
int hours = (time - minutes - seconds)/(3600);
|
||||
String h,m,s;
|
||||
s = (seconds< 10)? "0"+String.valueOf(seconds):String.valueOf(seconds);
|
||||
m = (minutes< 10)? "0"+String.valueOf(minutes):String.valueOf(minutes);
|
||||
h = (hours< 10)? "0"+String.valueOf(hours):String.valueOf(hours);
|
||||
playedTime.setText(h + ":" + m + ":" + s);
|
||||
|
||||
Date lastTimePlayedDate = gic.getLastTimePlayed();
|
||||
|
||||
DateFormat format = DateFormat.getDateTimeInstance();
|
||||
format.setTimeZone(TimeZone.getDefault());
|
||||
|
||||
lastTimePlayed.setText(format.format(lastTimePlayedDate));
|
||||
|
||||
return convertView;
|
||||
}
|
||||
|
|
|
@ -15,23 +15,61 @@
|
|||
android:src="@drawable/icon_default_9x9"/>
|
||||
|
||||
<RelativeLayout
|
||||
android:layout_width="0dp"
|
||||
android:layout_weight="4"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="match_parent">
|
||||
|
||||
<TextView
|
||||
android:text="ID"
|
||||
android:id="@+id/loadgame_listentry_id"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content" />
|
||||
<TextView
|
||||
android:text="GameType"
|
||||
android:id="@+id/loadgame_listentry_gametype"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content" />
|
||||
|
||||
<TextView
|
||||
android:text="gametype"
|
||||
android:layout_below="@+id/loadgame_listentry_id"
|
||||
android:id="@+id/loadgame_listentry_gametype"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content" />
|
||||
<LinearLayout
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:orientation="horizontal"
|
||||
android:layout_below="@+id/loadgame_listentry_gametype">
|
||||
|
||||
<RatingBar
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:id="@+id/loadgame_listentry_difficultybar"
|
||||
android:numStars="3"
|
||||
android:rating="3"
|
||||
android:clickable="false"
|
||||
style="?android:attr/ratingBarStyleSmall"/>
|
||||
|
||||
<TextView
|
||||
android:text="Difficulty"
|
||||
android:id="@+id/loadgame_listentry_difficultytext"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content" />
|
||||
|
||||
</LinearLayout>
|
||||
</RelativeLayout>
|
||||
|
||||
<RelativeLayout
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="match_parent"
|
||||
android:layout_gravity="right"
|
||||
android:gravity="right">
|
||||
|
||||
<TextView
|
||||
android:text="00:00"
|
||||
android:textStyle="bold"
|
||||
android:id="@+id/loadgame_listentry_timeplayed"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:gravity="end"/>
|
||||
|
||||
<TextView
|
||||
android:text="1 second ago"
|
||||
android:gravity="end"
|
||||
android:layout_below="@+id/loadgame_listentry_timeplayed"
|
||||
android:id="@+id/loadgame_listentry_lasttimeplayed"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content" />
|
||||
|
||||
</RelativeLayout>
|
||||
|
||||
</LinearLayout>
|
Loading…
Reference in a new issue