-
-
Save hoshi7/7aac7baa4238be697c84 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package jp.sample.app.samplefragment; | |
import android.app.Activity; | |
import android.os.Bundle; | |
import android.support.v4.app.Fragment; | |
import android.view.LayoutInflater; | |
import android.view.View; | |
import android.view.ViewGroup; | |
import android.widget.ImageView; | |
/** | |
* A simple {@link Fragment} subclass. | |
* Use the {@link ImageFragment#newInstance} factory method to | |
* create an instance of this fragment. | |
* | |
*/ | |
public class ImageFragment extends Fragment { | |
private static final String ARG_SECTION_NUMBER = "section_number"; | |
private static final String ARG_PARAM_RESOURCE_ID = "resource_id"; | |
private int mResourceId; | |
/** | |
* Use this factory method to create a new instance of | |
* this fragment using the provided parameters. | |
* | |
* @param resourceId Parameter 1. | |
* @return A new instance of fragment ImageFragment. | |
*/ | |
// TODO: Rename and change types and number of parameters | |
public static ImageFragment newInstance(int sectionNumber, int resourceId) { | |
ImageFragment fragment = new ImageFragment(); | |
Bundle args = new Bundle(); | |
args.putInt(ARG_SECTION_NUMBER, sectionNumber); | |
args.putInt(ARG_PARAM_RESOURCE_ID, resourceId); | |
fragment.setArguments(args); | |
return fragment; | |
} | |
public ImageFragment() { | |
// Required empty public constructor | |
} | |
@Override | |
public void onCreate(Bundle savedInstanceState) { | |
super.onCreate(savedInstanceState); | |
if (getArguments() != null) { | |
mResourceId = getArguments().getInt(ARG_PARAM_RESOURCE_ID); | |
} | |
} | |
@Override | |
public View onCreateView(LayoutInflater inflater, ViewGroup container, | |
Bundle savedInstanceState) { | |
// Inflate the layout for this fragment | |
View rootView = inflater.inflate(R.layout.fragment_image, container, false); | |
ImageView imageView = (ImageView)rootView.findViewById(R.id.image_view); | |
imageView.setImageResource(mResourceId); | |
return rootView; | |
} | |
@Override | |
public void onAttach(Activity activity) { | |
super.onAttach(activity); | |
((MainActivity) activity).onSectionAttached( getArguments().getInt(ARG_SECTION_NUMBER)); | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package jp.sample.app.samplefragment; | |
import android.app.Activity; | |
import android.os.Bundle; | |
import android.support.v4.app.ListFragment; | |
import android.view.View; | |
import android.widget.ArrayAdapter; | |
import android.widget.ListView; | |
import jp.sample.app.samplefragment.dummy.DummyContent; | |
/** | |
* A fragment representing a list of Items. | |
* <p /> | |
* <p /> | |
* Activities containing this fragment MUST implement the {@link Callbacks} | |
* interface. | |
*/ | |
public class ItemFragment extends ListFragment { | |
private static final String ARG_SECTION_NUMBER = "section_number"; | |
private OnFragmentInteractionListener mListener; | |
// TODO: Rename and change types of parameters | |
public static ItemFragment newInstance(int sectionNumber) { | |
ItemFragment fragment = new ItemFragment(); | |
Bundle args = new Bundle(); | |
args.putInt(ARG_SECTION_NUMBER, sectionNumber); | |
fragment.setArguments(args); | |
return fragment; | |
} | |
/** | |
* Mandatory empty constructor for the fragment manager to instantiate the | |
* fragment (e.g. upon screen orientation changes). | |
*/ | |
public ItemFragment() { | |
} | |
@Override | |
public void onCreate(Bundle savedInstanceState) { | |
super.onCreate(savedInstanceState); | |
// TODO: Change Adapter to display your content | |
setListAdapter(new ArrayAdapter<DummyContent.DummyItem>(getActivity(), | |
android.R.layout.simple_list_item_1, android.R.id.text1, DummyContent.ITEMS)); | |
} | |
@Override | |
public void onAttach(Activity activity) { | |
super.onAttach(activity); | |
try { | |
mListener = (OnFragmentInteractionListener) activity; | |
} catch (ClassCastException e) { | |
throw new ClassCastException(activity.toString() | |
+ " must implement OnFragmentInteractionListener"); | |
} | |
((MainActivity) activity).onSectionAttached( getArguments().getInt(ARG_SECTION_NUMBER)); | |
} | |
@Override | |
public void onDetach() { | |
super.onDetach(); | |
mListener = null; | |
} | |
@Override | |
public void onListItemClick(ListView l, View v, int position, long id) { | |
super.onListItemClick(l, v, position, id); | |
if (null != mListener) { | |
// Notify the active callbacks interface (the activity, if the | |
// fragment is attached to one) that an item has been selected. | |
mListener.onFragmentInteraction(DummyContent.ITEMS.get(position).id); | |
} | |
} | |
/** | |
* This interface must be implemented by activities that contain this | |
* fragment to allow an interaction in this fragment to be communicated | |
* to the activity and potentially other fragments contained in that | |
* activity. | |
* <p> | |
* See the Android Training lesson <a href= | |
* "http://developer.android.com/training/basics/fragments/communicating.html" | |
* >Communicating with Other Fragments</a> for more information. | |
*/ | |
public interface OnFragmentInteractionListener { | |
// TODO: Update argument type and name | |
public void onFragmentInteraction(String id); | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package jp.sample.app.samplefragment; | |
import android.support.v7.app.ActionBarActivity; | |
import android.support.v7.app.ActionBar; | |
import android.support.v4.app.FragmentManager; | |
import android.os.Bundle; | |
import android.view.Menu; | |
import android.view.MenuItem; | |
import android.support.v4.widget.DrawerLayout; | |
public class MainActivity extends ActionBarActivity | |
implements NavigationDrawerFragment.NavigationDrawerCallbacks,ItemFragment.OnFragmentInteractionListener{ | |
/** | |
* Fragment managing the behaviors, interactions and presentation of the navigation drawer. | |
*/ | |
private NavigationDrawerFragment mNavigationDrawerFragment; | |
/** | |
* Used to store the last screen title. For use in {@link #restoreActionBar()}. | |
*/ | |
private CharSequence mTitle; | |
@Override | |
protected void onCreate(Bundle savedInstanceState) { | |
super.onCreate(savedInstanceState); | |
setContentView(R.layout.activity_main); | |
mNavigationDrawerFragment = (NavigationDrawerFragment) | |
getSupportFragmentManager().findFragmentById(R.id.navigation_drawer); | |
mTitle = getTitle(); | |
// Set up the drawer. | |
mNavigationDrawerFragment.setUp( | |
R.id.navigation_drawer, | |
(DrawerLayout) findViewById(R.id.drawer_layout)); | |
} | |
@Override | |
public void onNavigationDrawerItemSelected(int position) { | |
// update the main content by replacing fragments | |
FragmentManager fragmentManager = getSupportFragmentManager(); | |
if(position == 0){ | |
fragmentManager.beginTransaction() | |
.replace(R.id.container, ImageFragment.newInstance(position + 1, R.drawable.hanabatake)) | |
.commit(); | |
} | |
else if(position == 1){ | |
fragmentManager.beginTransaction() | |
.replace(R.id.container, TextFragment.newInstance(position + 1)) | |
.commit(); | |
} | |
else if(position == 2){ | |
fragmentManager.beginTransaction() | |
.replace(R.id.container, ItemFragment.newInstance(position + 1)) | |
.commit(); | |
} | |
} | |
public void onSectionAttached(int number) { | |
switch (number) { | |
case 1: | |
mTitle = getString(R.string.title_section1); | |
break; | |
case 2: | |
mTitle = getString(R.string.title_section2); | |
break; | |
case 3: | |
mTitle = getString(R.string.title_section3); | |
break; | |
} | |
} | |
public void restoreActionBar() { | |
ActionBar actionBar = getSupportActionBar(); | |
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_STANDARD); | |
actionBar.setDisplayShowTitleEnabled(true); | |
actionBar.setTitle(mTitle); | |
} | |
@Override | |
public boolean onCreateOptionsMenu(Menu menu) { | |
if (!mNavigationDrawerFragment.isDrawerOpen()) { | |
// Only show items in the action bar relevant to this screen | |
// if the drawer is not showing. Otherwise, let the drawer | |
// decide what to show in the action bar. | |
getMenuInflater().inflate(R.menu.main, menu); | |
restoreActionBar(); | |
return true; | |
} | |
return super.onCreateOptionsMenu(menu); | |
} | |
@Override | |
public boolean onOptionsItemSelected(MenuItem item) { | |
// Handle action bar item clicks here. The action bar will | |
// automatically handle clicks on the Home/Up button, so long | |
// as you specify a parent activity in AndroidManifest.xml. | |
int id = item.getItemId(); | |
if (id == R.id.action_settings) { | |
return true; | |
} | |
return super.onOptionsItemSelected(item); | |
} | |
@Override | |
public void onFragmentInteraction(String id) { | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package jp.sample.app.samplefragment; | |
import android.app.Activity; | |
import android.os.Bundle; | |
import android.support.v4.app.Fragment; | |
import android.view.LayoutInflater; | |
import android.view.View; | |
import android.view.ViewGroup; | |
/** | |
* A simple {@link Fragment} subclass. | |
* Use the {@link TextFragment#newInstance} factory method to | |
* create an instance of this fragment. | |
* | |
*/ | |
public class TextFragment extends Fragment { | |
private static final String ARG_SECTION_NUMBER = "section_number"; | |
/** | |
* Use this factory method to create a new instance of | |
* this fragment using the provided parameters. | |
* | |
* @return A new instance of fragment TextFragment. | |
*/ | |
// TODO: Rename and change types and number of parameters | |
public static TextFragment newInstance(int sectionNumber) { | |
TextFragment fragment = new TextFragment(); | |
Bundle args = new Bundle(); | |
args.putInt(ARG_SECTION_NUMBER, sectionNumber); | |
fragment.setArguments(args); | |
return fragment; | |
} | |
public TextFragment() { | |
// Required empty public constructor | |
} | |
@Override | |
public void onCreate(Bundle savedInstanceState) { | |
super.onCreate(savedInstanceState); | |
} | |
@Override | |
public View onCreateView(LayoutInflater inflater, ViewGroup container, | |
Bundle savedInstanceState) { | |
// Inflate the layout for this fragment | |
return inflater.inflate(R.layout.fragment_text, container, false); | |
} | |
@Override | |
public void onAttach(Activity activity) { | |
super.onAttach(activity); | |
((MainActivity) activity).onSectionAttached( getArguments().getInt(ARG_SECTION_NUMBER)); | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment