0

MainActivity에서 두 개의 다른 SimpleCursorAdapters 및 연결된 ListView가 있습니다.ContentProvider에서 onLoadFinished가 제대로 호출되지 않았습니다.

초기화 후 양쪽 모두의 로더가 생성되어 올바르게 반환 된 데이터로 ContentProvider에서 쿼리를 실행했습니다.

LoaderManager 구현 :

@Override 
    public Loader<Cursor> onCreateLoader(int id, Bundle args) { 
     CursorLoader loader = null; 

     switch (id) { 
      case 0: 
       loader = new CursorLoader(this, 
         DataProvider.CONTENT_URI_PROFILE_Match, 
         new String[]{DataProvider.COL_ID, DataProvider.COL_MATCH_NAME, DataProvider.COL_COUNT, DataProvider.COL_MATCH_PROFILE_IMAGE, DataProvider.COL_MATCH_BIRTH_DATE}, 
         null, 
         null, 
         DataProvider.COL_ID + " DESC"); 
       break; 
      case 2: 
       loader = new CursorLoader(this, 
         DataProvider.CONTENT_URI_PROFILE_Trash, 
         new String[]{DataProvider.COL_ID, DataProvider.COL_MATCH_NAME, DataProvider.COL_EXPIRATION_STATUS, DataProvider.COL_MATCH_PROFILE_IMAGE, DataProvider.COL_MATCH_BIRTH_DATE}, 
         null, 
         null, 
         DataProvider.COL_ID + " DESC"); 
       break; 
     } 
     return loader; 
    } 

    @Override 
    public void onLoadFinished(Loader<Cursor> loader, Cursor data) { 
     switch (loader.getId()) { 
      case 0: 
       adapterMatch.swapCursor(data); 
       break; 
      case 2: 
       adapterTrash.swapCursor(data); 
       break; 
     } 
    } 

이 애플리케이션은 다음과 같이 작동합니다. 브로드 캐스트 리시버에 서버에서 메시지를 수신 할 때, 코드의 일부가 아래 수신기 클래스에서 실행 및 삽입 새 값이 SQLite 데이터베이스를 서버에서받은 후

이 커서 데이터가
ContentValues values = new ContentValues(5); 
        values.put(DataProvider.COL_MATCH_ID, matchedUser); 
        values.put(DataProvider.COL_EXPIRATION_STATUS, expirationStatus); 
        values.put(DataProvider.COL_MATCH_NAME, matchName); 
        values.put(DataProvider.COL_MATCH_BIRTH_DATE, matchBirthDate); 
        values.put(DataProvider.COL_MATCH_PROFILE_IMAGE, matchProfileImage); 
        context.getContentResolver().insert(DataProvider.CONTENT_URI_PROFILE_Match, values); 

내 문제가되는 컨텐트 프로를 통해 DB에 행을 삽입 MainActivity에 전달되지 않으므로 다음에 작업이 생성 될 때까지 UI를 업데이트하지 않습니다.

다음은 내 컨텐트 프로에서 강조 표시된 코드입니다 :

public static final Uri CONTENT_URI_MESSAGES = Uri.parse("content://com.example.vcc4.mashroom.provider/messages"); 
    public static final Uri CONTENT_URI_PROFILE = Uri.parse("content://com.example.vcc4.mashroom.provider/profile"); 
    public static final Uri CONTENT_URI_PROFILE_Match = Uri.parse("content://com.example.vcc4.mashroom.provider/match"); 
    public static final Uri CONTENT_URI_PROFILE_Trash = Uri.parse("content://com.example.vcc4.mashroom.provider/trash"); 

private static final UriMatcher uriMatcher; 
    static { 
     uriMatcher = new UriMatcher(UriMatcher.NO_MATCH); 
     uriMatcher.addURI("com.example.vcc4.mashroom.provider", "messages", MESSAGES_ALLROWS); 
     uriMatcher.addURI("com.example.vcc4.mashroom.provider", "messages/#", MESSAGES_SINGLE_ROW); 
     uriMatcher.addURI("com.example.vcc4.mashroom.provider", "profile", PROFILE_ALLROWS); 
     uriMatcher.addURI("com.example.vcc4.mashroom.provider", "profile/#", PROFILE_SINGLE_ROW); 
     uriMatcher.addURI("com.example.vcc4.mashroom.provider", "match", PROFILE_AllROWS_MATCH); 
     uriMatcher.addURI("com.example.vcc4.mashroom.provider", "match/#", PROFILE_SINGLE_ROWS_MATCH); 
     uriMatcher.addURI("com.example.vcc4.mashroom.provider", "trash", PROFILE_ALLROWS_TRASH); 
    } 

@Override 
    public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) { 
     SQLiteDatabase db = dbHelper.getReadableDatabase(); 
     SQLiteQueryBuilder qb = new SQLiteQueryBuilder(); 

     switch(uriMatcher.match(uri)) { 
     case MESSAGES_ALLROWS: 
      qb.setTables(TABLE_MESSAGES); 
      break;   

     case MESSAGES_SINGLE_ROW: 
      qb.setTables(TABLE_MESSAGES); 
      qb.appendWhere("_id = " + uri.getLastPathSegment()); 
      break; 

     case PROFILE_ALLROWS: 
      qb.setTables(TABLE_PROFILE); 
      break;   

     case PROFILE_SINGLE_ROW: 
      qb.setTables(TABLE_PROFILE); 
      qb.appendWhere("_id = " + uri.getLastPathSegment()); 
      break; 

     case PROFILE_AllROWS_MATCH: 
      qb.setTables(TABLE_PROFILE); 
      qb.appendWhere(COL_EXPIRATION_STATUS + " = " + "'wait'" + " OR " + COL_EXPIRATION_STATUS + " = " + "'active'"); 
      break; 

     case PROFILE_ALLROWS_TRASH: 
      qb.setTables(TABLE_PROFILE); 
      qb.appendWhere(COL_EXPIRATION_STATUS + " = " + "'expired'"); 
      break; 

     default: 
      throw new IllegalArgumentException("Unsupported URI: " + uri);   
     } 

     Cursor c = qb.query(db, projection, selection, selectionArgs, null, null, sortOrder); 
     c.setNotificationUri(getContext().getContentResolver(), uri); 
     return c; 
    } 

@Override 
    public Uri insert(Uri uri, ContentValues values) { 
     SQLiteDatabase db = dbHelper.getWritableDatabase(); 

     long id; 
     switch(uriMatcher.match(uri)) { 
     case MESSAGES_ALLROWS: 
      id = db.insertOrThrow(TABLE_MESSAGES, null, values); 
      if (values.get(COL_TO) == null) { 
       db.execSQL("update profile set count = count+1 where email = ?", new Object[]{values.get(COL_FROM)}); 
       getContext().getContentResolver().notifyChange(CONTENT_URI_PROFILE, null); 
      } 
      break; 

     case PROFILE_ALLROWS: 
      id = db.insertOrThrow(TABLE_PROFILE, null, values); 
      break; 

     case PROFILE_AllROWS_MATCH: 
      id = db.insertOrThrow(TABLE_PROFILE, null, values); 
      break; 

     default: 
      throw new IllegalArgumentException("Unsupported URI: " + uri); 
     } 

     Uri insertUri = ContentUris.withAppendedId(uri, id); 
     getContext().getContentResolver().notifyChange(insertUri, null); 

     return insertUri; 
    } 

내가 질문과 안드로이드 자원 SO 많이 검색 한하지만,이 문제를 해결하기 위해 어떤 단서를 찾을 수 없습니다. 어떤 해결책을 주시겠습니까?

편집 : 아래 SimpleCursorAdapters 설정하기위한 코드를 추가 :

adapterMatch = new SimpleCursorAdapter(this, 
       R.layout.main_list_item, 
       null, 
       new String[]{DataProvider.COL_MATCH_PROFILE_IMAGE, DataProvider.COL_MATCH_NAME, DataProvider.COL_MATCH_BIRTH_DATE, DataProvider.COL_COUNT, DataProvider.COL_MATCH_ID}, 
       new int[]{R.id.avatar, R.id.text1, R.id.text2, R.id.text3}, 
       0); 
adapterWatch = new SimpleCursorAdapter(this, 
        R.layout.main_list_item, 
        null, 
        new String[]{DataProvider.COL_MATCH_PROFILE_IMAGE, DataProvider.COL_MATCH_NAME, DataProvider.COL_MATCH_BIRTH_DATE, DataProvider.COL_MUTUAL_ACTION, DataProvider.COL_EXPIRATION_STATUS, DataProvider.COL_MATCH_ID}, 
        new int[]{R.id.avatar, R.id.text1, R.id.text2, R.id.text3}, 
        0); 
adapterTrash = new SimpleCursorAdapter(this, 
        R.layout.main_list_item, 
        null, 
        new String[]{DataProvider.COL_MATCH_PROFILE_IMAGE, DataProvider.COL_MATCH_NAME, DataProvider.COL_MATCH_BIRTH_DATE, DataProvider.COL_EXPIRATION_STATUS}, 
        new int[]{R.id.avatar, R.id.text1, R.id.text2, R.id.text3}, 
        0); 

답변

0

그것은 아무것도하지 않을 수 있습니다,하지만 당신은 디버깅과 insert의 4 번째 마지막 줄에 insertUri 변수의 값을 확인을 마음 것 일치가 삽입되면 ContentProvider

+0

inertUri 변수는 "content : //com.example.vcc4.mashroom.provider/match"입니다. 일치 항목 삽입 후 –

+0

감사! 좋아, 내가 생각했던 것처럼 보이지 않아. – clownba0t

+0

로드 된 데이터를 처리하는 데 사용하는'SimpleCursorAdapter'를 생성하는 코드를 게시 하시겠습니까? – clownba0t