Основная проблема, с которой вы столкнулись, заключается в том, что вы не вызываете заполнение списка после получения даты.Скорее всего, представление списка заполняется до того, как будет получена дата.
Это код: -
DatabaseHelper dbHelp = new DatabaseHelper(this);
int huntID = dbHelp.getHuntIDforPastHunts(strDate);
if (huntID == 0)
{
Toast.makeText(getApplicationContext(), "No Hunts on that day.", Toast.LENGTH_LONG).show();
}
else
{
LastPart(huntID);
}
выполнится до того, как вы получите дату, поэтому без даты нет данных
Существуют и другие проблемы, например, каждый раз, когда вы нажимаете кнопку, вы создаете новый адаптер, когда вы должны использовать его и обновлять список.
Ниже описано, какпредложить сделать это, и это рабочий код и был протестирован.Однако для тестирования мне пришлось угадать большую часть DatabaseHelper, поскольку все, что было доступно, это метод getPastHuntLogs.
DatabaseHelper.java использовалось: -
public class DatabaseHelper extends SQLiteOpenHelper {
/**
* Suggest using 1 definitaion of table and column names and to ALWAYS use the constants
*/
public static final String DBNAME = "hunter";
public static final int DBVERSION = 1;
public static final String TABLE_LOG = "Log";
public static final String COL_TIMESTAMP = "timestamp";
public static final String COl_LOG_HUNTID = "HuntID";
public static final String COL_LOG_BIRDNAME = "BirdName";
public static final String COL_LOG_SEENORSHOT = "SeenOrShot";
public static final String COL_LOG_BIRDAGE = "BirdAge";
public static final String COL_LOG_NUMSEENORSHOT = "NumSeenOrShot";
public static final String COL_LOG_OTHERANIMALSSHOTORCLAYSHOOT = "OtherAnimalShotORClayShoot";
public static final String COL_LOG_ANIMALSHORORTYPECLAYSHOOT = "AnimalShotNameORTypeClaysShot";
SQLiteDatabase db;
public DatabaseHelper(Context context) {
super(context, DBNAME, null, DBVERSION);
db = this.getWritableDatabase();
}
/**
* Guestimate
* @param db
*/
@Override
public void onCreate(SQLiteDatabase db) {
String crt_log_tbl_sql = "CREATE TABLE IF NOT EXISTS " + TABLE_LOG + "(" +
COl_LOG_HUNTID + " INTEGER PRIMARY KEY, " +
COL_TIMESTAMP + " TEXT DEFAULT CURRENT_TIMESTAMP, " +
COL_LOG_BIRDNAME + " TEXT, " +
COL_LOG_SEENORSHOT + " TEXT, " +
COL_LOG_BIRDAGE + " REAL," +
COL_LOG_NUMSEENORSHOT + " INTEGER, " +
COL_LOG_OTHERANIMALSSHOTORCLAYSHOOT + " TEXT," +
COL_LOG_ANIMALSHORORTYPECLAYSHOOT + " TEXT " +
")";
db.execSQL(crt_log_tbl_sql);
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
}
/**
* Added so I could see the rows in the log
*/
public void dumpLogTable() {
Cursor csr = db.query(TABLE_LOG,null,null,null,null,null,null);
DatabaseUtils.dumpCursor(csr);
csr.close();
}
/**
* Guestimate. (note converts dates to YYYY-MM-DD format as stored )
* @param strDate
* @return
*/
public int getHuntIDforPastHunts(String strDate) {
int rv = 0;
String[] datevalues = strDate.split("/");
String srchdate = datevalues[2] + "-" + datevalues[1] + "-" + datevalues[0];
String whereclause = "date(" + COL_TIMESTAMP + ")=?";
String[] whereargs = new String[]{srchdate};
Cursor csr = db.query(TABLE_LOG,null,whereclause,whereargs,null,null,null);
if (csr.moveToFirst()) {
rv = csr.getInt(csr.getColumnIndex(COl_LOG_HUNTID));
}
return rv;
}
/**
* ALlows some testing data to be added
* @param birdname
* @param seenorshot
* @param birdage
* @param numseenorshot
* @param otheranimalshotorclayshoot
* @param animalshotortypeclayshoot
* @return
*/
public long insertLog(String birdname, String seenorshot,double birdage, int numseenorshot, String otheranimalshotorclayshoot, String animalshotortypeclayshoot) {
ContentValues cv = new ContentValues();
cv.put(COL_LOG_BIRDNAME,birdname);
cv.put(COL_LOG_SEENORSHOT,seenorshot);
cv.put(COL_LOG_BIRDAGE,birdage);
cv.put(COL_LOG_NUMSEENORSHOT,numseenorshot);
cv.put(COL_LOG_OTHERANIMALSSHOTORCLAYSHOOT,otheranimalshotorclayshoot);
cv.put(COL_LOG_ANIMALSHORORTYPECLAYSHOOT,animalshotortypeclayshoot);
return db.insert(TABLE_LOG,null,cv);
}
/**
* Very much as was
* @param huntID
* @return
*/
public Cursor getPastHuntLogs(int huntID)
{
String query = "SELECT HuntID AS _id, BirdName, SeenORShot, BirdAge, NumSeenORShot, OtherAnimalShotORClayShoot, " +
"AnimalShotNameORTypeClaysShot FROM Log " +
"WHERE HuntID = " + String.valueOf(huntID) + //<<<<<<<<<< Changed
""; //<<<<<<<<<< ADDED so that WHERE...... can be commented out so select all
return db.rawQuery(query, null); //<<<<<<<< returns cursor directly
}
}
PreviousHunts.java
public class PreviousHunts extends AppCompatActivity implements View.OnClickListener {
public TextView txtDate;
public String strDate = "";
public ListView lstView;
SimpleCursorAdapter adapter; //<<<<<<<<<< ADDED
DatabaseHelper dbHelp; //<<<<<<<<<< ADDED
Cursor cursor; //<<<<<<<<<< ADDED
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_previous_hunts);
Button btnDateGet = findViewById(R.id.btnGetHunts);
btnDateGet.setOnClickListener(this);
Button btnHome = findViewById(R.id.btnHuntsHome);
btnHome.setOnClickListener(this);
txtDate = findViewById(R.id.txtDateThing);
lstView = findViewById(R.id.lstView);
dbHelp = new DatabaseHelper(this); //<<<<<<<<<< ADDED
addSomeTestData(); //<<<<<<<<<< ADDDED
}
@Override
public void onClick(View v)
{
switch (v.getId())
{
case R.id.btnGetHunts:
getDate();
break;
case R.id.btnHuntsHome:
goHome();
break;
}
}
private void getDate()
{
final Calendar c = Calendar.getInstance();
final int Year = c.get(Calendar.YEAR);
final int Month = c.get(Calendar.MONTH);
final int Day = c.get(Calendar.DAY_OF_MONTH);
DatePickerDialog datePickerDialog = new DatePickerDialog(this, new DatePickerDialog.OnDateSetListener()
{
@Override
public void onDateSet(DatePicker view, int year, int month, int dayOfMonth)
{
String day = String.valueOf(dayOfMonth);
String Smonth = String.valueOf(month + 1);
String sYear = String.valueOf(year);
txtDate.setText(day + "/" + Smonth + "/" + sYear);
strDate = day + "/" + Smonth + "/" + sYear;
displayHuntList(strDate); //<<<<<<<<<< CHANGED calls displayHuntList
}
},Year, Month, Day);
datePickerDialog.show();
}
//<<<<<<<<<< NEW replaces last_hunt code
public void displayHuntList(String strDate) {
int huntID = dbHelp.getHuntIDforPastHunts(strDate);
if (huntID < 1) {
Toast.makeText(getApplicationContext(), "No Hunts on that day.", Toast.LENGTH_LONG).show();
}
cursor = dbHelp.getPastHuntLogs(huntID);
//<<<<<<<<<< Only create a SimpleCursorAdapter instance once and reuse
//<<<<<<<<<< NOTE!! Stock layout used for convenience >>>>>>>>>>
if (adapter == null) {
adapter = new SimpleCursorAdapter(this,
android.R.layout.simple_list_item_2,
cursor,
new String[]{DatabaseHelper.COL_LOG_BIRDNAME,
DatabaseHelper.COL_LOG_SEENORSHOT},
new int[]{android.R.id.text1,android.R.id.text2},
0
);
lstView.setAdapter(adapter);
} else {
// if called after the initial call just swap the cursor to refresh the list
adapter.swapCursor(cursor);
}
}
private void goHome()
{
//<<<<<<<<<< Commented body out so hitting HOME does nothing >>>>>>>>>>
/*
Intent intent = new Intent(PreviousHunts.this, Home_Screen.class);
startActivity(intent);
finish();
*/
}
/**
* Added so some testing data is added (note 2 rows added each time App is run)
* All rows have a timestamp as per the day the App is run (ok for testing)
*/
private void addSomeTestData() {
dbHelp.insertLog("Pheasant","Seen",1.75,100,"N/A","N/A");
dbHelp.insertLog("Grouse","SHOT",2.3,10,"NO","MAYBE");
dbHelp.dumpLogTable();
}
}
- Надеюсь, большая часть кода будет знакома, комментариидолжно помочь
- Обратите внимание, что в списке только когда-либо отображается 1, поскольку выбор осуществляется через huntID (возможно, это из другой таблицы, я так думаю) (комментируя строку WHERE в Метод getPastHuntLogs в DatabaseHelper.java выведет список всех строк).
Результат 1
При запуске (обратите внимание, я установил фон ListView такэто было легко увидеть): -

Результат 2
После нажатия кнопки и выбора текущей даты: -
