package com.meg7.soas.ui; import android.content.Intent; import android.os.Bundle; import android.support.v4.app.ActivityCompat; import android.support.v4.app.ActivityOptionsCompat; import android.support.v4.app.NavUtils; import android.view.MenuItem; import android.view.View; import com.meg7.soas.R; import com.meg7.soas.data.Photo; import com.meg7.soas.ui.fragment.PhotoDetailFragment; import org.parceler.Parcels; /** * An activity representing a single Repo detail screen. This * activity is only used on handset devices. On tablet-size devices, * item details are presented side-by-side with a list of items * in a {@link PhotosListActivity}. * <p> * This activity is mostly just a 'shell' activity containing nothing * more than a {@link com.meg7.soas.ui.fragment.PhotoDetailFragment}. */ // Based on http://www.vogella.com/tutorials/AndroidFragments/article.html public class PhotoDetailActivity extends BaseActivity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // savedInstanceState is non-null when there is fragment state // saved from previous configurations of this activity // (e.g. when rotating the screen from portrait to landscape). // In this case, the fragment will automatically be re-added // to its container so we don't need to manually add it. // For more information, see the Fragments API guide at: // // http://developer.android.com/guide/components/fragments.html // if (savedInstanceState == null) { // Create the detail fragment and add it to the activity // using a fragment transaction. PhotoDetailFragment fragment = PhotoDetailFragment.newInstance( getIntent().getParcelableExtra(PhotoDetailFragment.ARG_PHOTO)); getFragmentManager().beginTransaction() .add(R.id.photoDetailContainer, fragment) .commit(); } } @Override protected int getLayoutResource() { return R.layout.activity_photo_detail; } @Override public boolean onOptionsItemSelected(MenuItem item) { int id = item.getItemId(); if (id == android.R.id.home) { // This ID represents the Home or Up button. In the case of this // activity, the Up button is shown. Use NavUtils to allow users // to navigate up one level in the application structure. For // more details, see the Navigation pattern on Android Design: // // http://developer.android.com/design/patterns/navigation.html#up-vs-back // NavUtils.navigateUpTo(this, new Intent(this, PhotosListActivity.class)); return true; } return super.onOptionsItemSelected(item); } public static void launch(BaseActivity activity, View transitionView, Photo photo) { ActivityOptionsCompat options = ActivityOptionsCompat.makeSceneTransitionAnimation( activity, transitionView, PhotoDetailFragment.ARG_PHOTO); Intent intent = new Intent(activity, PhotoDetailActivity.class); intent.putExtra(PhotoDetailFragment.ARG_PHOTO, Parcels.wrap(photo)); ActivityCompat.startActivity(activity, intent, options.toBundle()); } }