2016-06-01 21 views
0

私はWebサーバーを呼び出してJSONデータをプルダウンして解析し、S​​QLiteデータベースに保存して情報を表示するアプリケーションを作成していますユーザー。最初にロードされたときにCursorAdapterが画像を表示しない

アプリの最初のページに映画のポスターが表示されるだけです。アプリケーションが新しくインストールされるたびに、GridViewは更新されませんが、閉じて再オープンすると、必要に応じてムービーポスターが表示されます。私はそれが新しくインストールされたときに更新されないことを間違っているかどうかはわかりません。ここで

は私のコードです。

MainActivityFrament

public void update() { 
    Log.e(LOG_TAG, "In onUpdate"); 
    FetchMovieTask movieTask = new FetchMovieTask(getContext()); 
    SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(getActivity()); 
    String userChoice = sharedPreferences.getString(getString(R.string.pref_sort_key), getString(R.string.pref_sort_value_mostpop)); 
    movieTask.execute(userChoice); 
    progressBar.setVisibility(View.VISIBLE); 
} 

@Override 
public void onStart() { 
    super.onStart(); 
    Log.e(LOG_TAG, "In onStart"); 
    update(); 
} 

@Override 
public void onActivityCreated(Bundle savedInstanceState){ 
    Log.e(LOG_TAG, "In onActivityCreated"); 
    getLoaderManager().initLoader(MOVIE_LOADER, null, this); 
    super.onActivityCreated(savedInstanceState); 
} 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
         Bundle savedInstanceState) { 
    Log.e(LOG_TAG, "In onCreateView"); 
    Cursor cursor = getActivity().getContentResolver().query(MovieContract.MovieEntry.CONTENT_URI, null, null, null, null); 

    customAdapter = new CustomAdapter(getActivity(), cursor, 0); 

    View rootView = inflater.inflate(R.layout.fragment_main, container, false); 

    progressBar = (ProgressBar) rootView.findViewById(R.id.progressBar); 
    gridView = (GridView) rootView.findViewById(R.id.gridView_movies); 
    gridView.setAdapter(customAdapter); 
    gridView.setOnItemClickListener(new AdapterView.OnItemClickListener() { 
     @Override 
     public void onItemClick(AdapterView<?> parent, View view, int position, long id) { 
      Cursor cursor = (Cursor) parent.getItemAtPosition(position); 

      Log.i(LOG_TAG, "set movie object values"); 
      int _id = cursor.getInt(cursor.getColumnIndex(MovieContract.MovieEntry._ID)); 
      if (cursor != null) { 
       Intent intent = new Intent(getActivity(), MovieDetailActivity.class); 
       intent.putExtra("movieId", _id); 
       Log.i(LOG_TAG, "About to start intent"); 
       startActivity(intent); 
      } 
     } 

    }); 

    return rootView; 
} 

@Override 
public Loader<Cursor> onCreateLoader(int id, Bundle args) { 
    Log.e(LOG_TAG, "In onCreateLoader"); 
    return new CursorLoader(
      getActivity(), 
      MovieContract.MovieEntry.CONTENT_URI, 
      MOVIE_COLUMNS, 
      null, 
      null, 
      null 
    ); 
} 


@Override 
public void onLoadFinished(Loader<Cursor> loader, Cursor data) { 
    Log.e(LOG_TAG, "In onLoadFinished"); 
    customAdapter.swapCursor(data); 
} 


@Override 
public void onLoaderReset(Loader<Cursor> loader) { 
    Log.e(LOG_TAG, "In onLoadReset"); 
    customAdapter.swapCursor(null); 
} 

CursorAdapter

@Override 
public View newView(Context context, Cursor cursor, ViewGroup parent) { 
    Log.e(LOG_TAG, "In newView()"); 
    View view = LayoutInflater.from(context).inflate(R.layout.list_image_movie, parent, false); 

    return view; 
} 


@Override 
public void bindView(View view, Context context, Cursor cursor) { 

    Log.e(LOG_TAG, "in bindView()"); 
    String title =cursor.getString(cursor.getColumnIndex(MovieContract.MovieEntry.COLUMN_MOVIE_TITLE)); 
    Log.e(LOG_TAG, "Movie Title - " + title); 

    ImageView iv = (ImageView) view.findViewById(R.id.list_movie_pics_imageview); 

    int columIndex = cursor.getColumnIndex(MovieContract.MovieEntry.COLUMN_POSTER); 
    Bitmap image = Utility.getImage(cursor.getBlob(columIndex)); 

    iv.setImageBitmap(image); 
} 

AsyncTask

@Override 
protected Void doInBackground(String... params) { 
    Log.e(LOG_TAG, "In doInBackground"); 
    HttpURLConnection urlConnection = null; 
    BufferedReader reader = null; 

    String movieJsonStr = null; 

    try { 
     final String MOVIE_BASE_URL = "https://api.themoviedb.org/3/discover/movie?"; 
     final String SORT_PARAM = "sort_by"; 
     final String APIKEY_PARAM = "api_key"; 

     Uri builtUri = Uri.parse(MOVIE_BASE_URL).buildUpon() 
       .appendQueryParameter(SORT_PARAM, params[0]) 
       .appendQueryParameter(APIKEY_PARAM, BuildConfig.OPEN_MOVIE_MAP_API_KEY) 
       .build(); 

     URL url = new URL(builtUri.toString()); 

     Log.v(LOG_TAG, "Built URI :" + builtUri.toString()); 

     urlConnection = (HttpURLConnection) url.openConnection(); 
     urlConnection.setRequestMethod("GET"); 
     urlConnection.connect(); 

     InputStream inputStream = urlConnection.getInputStream(); 

     StringBuffer buffer = new StringBuffer(); 
     if (inputStream == null) { 
      return null; 
     } 

     reader = new BufferedReader(new InputStreamReader(inputStream)); 

     String line; 
     while ((line = reader.readLine()) != null) { 
      buffer.append(line + "\n"); 
     } 

     if (buffer.length() == 0) { 
      return null; 
     } 

     movieJsonStr = buffer.toString(); 
     parseMovieData(new JSONObject(movieJsonStr)); 
     checkDBValues(mContext); 
    } catch (IOException e) { 
     e.printStackTrace(); 
    } catch (JSONException e) { 
     e.printStackTrace(); 
    } finally { 

     if (urlConnection != null) { 
      urlConnection.disconnect(); 
     } 

     if (reader != null) { 
      try { 
       reader.close(); 
      } catch (final IOException e) { 
       Log.e(LOG_TAG, "Error closing stream", e); 
      } 
     } 
    } 
    return null; 
} 

@Override 
protected void onPostExecute(Void aVoid) { 
    Log.e(LOG_TAG, "In onPostExecute"); 
    customAdapter.notifyDataSetChanged(); 
    MainActivityFragment.progressBar.setVisibility(View.GONE); 
} 

public void parseMovieData(JSONObject movieData) { 
    Log.e(LOG_TAG, "In parseMovieData"); 
    try { 
     JSONArray movieArray = movieData.getJSONArray("results"); 

     Time dayTime = new Time(); 
     dayTime.setToNow(); 
     int julianStartDay = Time.getJulianDay(System.currentTimeMillis(), dayTime.gmtoff); 

     if (movieArray != null) { 
      for (int i = 0; i < movieArray.length(); i++) { 
       JSONObject movies = movieArray.getJSONObject(i); 

       long dateTime = dayTime.setJulianDay(julianStartDay + i); 
       Bitmap moviePoster = Utility.getBitmapFromURL(CustomAdapter.IMAGE_BASE_URL + movies.getString(CustomAdapter.IMAGE_PATH)); 
       String moviePosterUrl = CustomAdapter.IMAGE_BASE_URL + movies.getString(CustomAdapter.IMAGE_PATH); 
       String movieTitle = movies.getString(CustomAdapter.MOVIE_TITLE); 
       String movieDescription = movies.getString(CustomAdapter.MOVIE_DESCRIPTION); 
       double movieRating = movies.getDouble(CustomAdapter.MOVIE_RATING); 
       String movieReleaseDate = movies.getString(CustomAdapter.MOVIE_RELEASE_DATE); 

       ContentValues movieValues = new ContentValues(); 
       movieValues.put(MovieContract.MovieEntry.COLUMN_POSTER_URL, moviePosterUrl); 
       movieValues.put(MovieContract.MovieEntry.COLUMN_POSTER, Utility.getBytes(moviePoster)); 
       movieValues.put(MovieContract.MovieEntry.COLUMN_RELEASE_DATE, movieReleaseDate); 
       movieValues.put(MovieContract.MovieEntry.COLUMN_DESCRIPTION, movieDescription); 
       movieValues.put(MovieContract.MovieEntry.COLUMN_MOVIE_RATING, movieRating); 
       movieValues.put(MovieContract.MovieEntry.COLUMN_MOVIE_TITLE, movieTitle); 
       movieValues.put(MovieContract.MovieEntry.COLUMN_DATE, dateTime); 

       if (MovieProvider.rowExists(movieTitle)) { 
        continue; 
       } 

       insertMoviesToDB(movieValues); 
      } 
     } 
    } catch (JSONException e) { 
     e.printStackTrace(); 
    } 
} 

public void insertMoviesToDB(ContentValues movieValues){ 
    Log.e(LOG_TAG, "In insertMoviesToDB"); 
    MovieProvider.mOpenHelper.getReadableDatabase().insert(MovieContract.MovieEntry.TABLE_NAME, null, movieValues); 
} 

public void checkDBValues(Context context) { 
    Log.e(LOG_TAG, "In checkDBValues"); 
    Cursor cursor = context.getContentResolver().query(
      MovieContract.MovieEntry.CONTENT_URI, 
      null, 
      null, 
      null, 
      null 
    ); 

    int count = 0; 
    while (cursor.moveToNext()) { 
     count++; 
    } 
    Log.i(LOG_TAG, "Got " + count + " values from the DB"); 
} 

MainLayout

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 
     xmlns:tools="http://schemas.android.com/tools" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     tools:context=".MainActivityFragment"> 

<GridView 
     android:layout_width="fill_parent" 
     android:layout_height="match_parent" 
     android:verticalSpacing="0dp" 
     android:horizontalSpacing="0dp" 
     android:id="@+id/gridView_movies" 
     android:layout_gravity="center" 
     android:stretchMode="columnWidth" 
     android:numColumns="2"/> 

<ProgressBar 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:id="@+id/progressBar" 
    android:layout_gravity="center" 
    android:visibility="gone" /> 

私はすべての関連情報が含まれていると思います。エラーが発生していないので、関連するログは表示されません。追加情報が必要な場合は、尋ねてください。私はそれを提供します。

は、この上の任意の情報を大幅にonPostExecuteで

+0

あなたの発射時に非同期ですか? – Sush

+0

私はコードにそれを含めました。私はonStartメソッドで呼び出す。 – Dan

+0

R.layout.list_image_movie、親はこのレイアウトを投稿する。 – Sush

答えて

1

をいただければ幸い、notifyDatasetChangedはあなたのcustomAdapterのカーソルにデータとして動作しません。まだ同じです。

更新された情報で新しいカーソルを取得し、変更カーソルを呼び出す必要があります。したがってnotifyDataSetChangedの前には、このようなものにする必要があります

Cursor newCursor = getActivity().getContentResolver().query(MovieContract.MovieEntry.CONTENT_URI, null, null, null, null); 

customAdapter.changeCusrsor(newCursor); 

customAdapter.notifyDataSetChanged(); 
+0

私は 'onPostExecute'メソッドでこれを試しましたが、 getActivity()を呼び出すには – Dan

+0

getContentResolverを呼び出すコンテキストが必要です。getActivity()が許可されていない場合、コンストラクタでasynctaskにコンテキストを渡して、そのコンテキストをonPostExecuteで使用します。 – Sarang

+0

私はそれを試みましたが、それでも動作しません – Dan

関連する問題