• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2013 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.example.android.actionbarcompat.shareactionprovider;
18 
19 import android.content.Intent;
20 import android.os.Bundle;
21 import android.support.v4.view.MenuItemCompat;
22 import android.support.v4.view.PagerAdapter;
23 import android.support.v4.view.ViewPager;
24 import android.support.v7.app.ActionBarActivity;
25 import android.support.v7.widget.ShareActionProvider;
26 import android.view.LayoutInflater;
27 import android.view.Menu;
28 import android.view.MenuItem;
29 import android.view.View;
30 import android.view.ViewGroup;
31 import android.widget.ImageView;
32 import android.widget.TextView;
33 
34 import com.example.android.actionbarcompat.shareactionprovider.content.ContentItem;
35 
36 import java.util.ArrayList;
37 
38 /**
39  * This sample shows you how a provide a {@link ShareActionProvider} with ActionBarCompat,
40  * backwards compatible to API v7.
41  * <p>
42  * The sample contains a {@link ViewPager} which displays content of differing types: image and
43  * text. When a new item is selected in the ViewPager, the ShareActionProvider is updated with
44  * a share intent specific to that content.
45  * <p>
46  * This Activity extends from {@link ActionBarActivity}, which provides all of the function
47  * necessary to display a compatible Action Bar on devices running Android v2.1+.
48  */
49 public class MainActivity extends ActionBarActivity {
50 
51     // The items to be displayed in the ViewPager
52     private final ArrayList<ContentItem> mItems = getSampleContent();
53 
54     // Keep reference to the ShareActionProvider from the menu
55     private ShareActionProvider mShareActionProvider;
56 
57     @Override
onCreate(Bundle savedInstanceState)58     protected void onCreate(Bundle savedInstanceState) {
59         super.onCreate(savedInstanceState);
60 
61         // Set content view (which contains a CheeseListFragment)
62         setContentView(R.layout.sample_main);
63 
64         // Retrieve the ViewPager from the content view
65         ViewPager vp = (ViewPager) findViewById(R.id.viewpager);
66 
67         // Set an OnPageChangeListener so we are notified when a new item is selected
68         vp.setOnPageChangeListener(mOnPageChangeListener);
69 
70         // Finally set the adapter so the ViewPager can display items
71         vp.setAdapter(mPagerAdapter);
72     }
73 
74     // BEGIN_INCLUDE(get_sap)
75     @Override
onCreateOptionsMenu(Menu menu)76     public boolean onCreateOptionsMenu(Menu menu) {
77         // Inflate the menu resource
78         getMenuInflater().inflate(R.menu.main_menu, menu);
79 
80         // Retrieve the share menu item
81         MenuItem shareItem = menu.findItem(R.id.menu_share);
82 
83         // Now get the ShareActionProvider from the item
84         mShareActionProvider = (ShareActionProvider) MenuItemCompat.getActionProvider(shareItem);
85 
86         // Get the ViewPager's current item position and set its ShareIntent.
87         int currentViewPagerItem = ((ViewPager) findViewById(R.id.viewpager)).getCurrentItem();
88         setShareIntent(currentViewPagerItem);
89 
90         return super.onCreateOptionsMenu(menu);
91     }
92     // END_INCLUDE(get_sap)
93 
94     /**
95      * A PagerAdapter which instantiates views based on the ContentItem's content type.
96      */
97     private final PagerAdapter mPagerAdapter = new PagerAdapter() {
98         LayoutInflater mInflater;
99 
100         @Override
101         public int getCount() {
102             return mItems.size();
103         }
104 
105         @Override
106         public boolean isViewFromObject(View view, Object o) {
107             return view == o;
108         }
109 
110         @Override
111         public void destroyItem(ViewGroup container, int position, Object object) {
112             // Just remove the view from the ViewPager
113             container.removeView((View) object);
114         }
115 
116         @Override
117         public Object instantiateItem(ViewGroup container, int position) {
118             // Ensure that the LayoutInflater is instantiated
119             if (mInflater == null) {
120                 mInflater = LayoutInflater.from(MainActivity.this);
121             }
122 
123             // Get the item for the requested position
124             final ContentItem item = mItems.get(position);
125 
126             // The view we need to inflate changes based on the type of content
127             switch (item.contentType) {
128                 case ContentItem.CONTENT_TYPE_TEXT: {
129                     // Inflate item layout for text
130                     TextView tv = (TextView) mInflater
131                             .inflate(R.layout.item_text, container, false);
132 
133                     // Set text content using it's resource id
134                     tv.setText(item.contentResourceId);
135 
136                     // Add the view to the ViewPager
137                     container.addView(tv);
138                     return tv;
139                 }
140                 case ContentItem.CONTENT_TYPE_IMAGE: {
141                     // Inflate item layout for images
142                     ImageView iv = (ImageView) mInflater
143                             .inflate(R.layout.item_image, container, false);
144 
145                     // Load the image from it's content URI
146                     iv.setImageURI(item.getContentUri());
147 
148                     // Add the view to the ViewPager
149                     container.addView(iv);
150                     return iv;
151                 }
152             }
153 
154             return null;
155         }
156     };
157 
setShareIntent(int position)158     private void setShareIntent(int position) {
159         // BEGIN_INCLUDE(update_sap)
160         if (mShareActionProvider != null) {
161             // Get the currently selected item, and retrieve it's share intent
162             ContentItem item = mItems.get(position);
163             Intent shareIntent = item.getShareIntent(MainActivity.this);
164 
165             // Now update the ShareActionProvider with the new share intent
166             mShareActionProvider.setShareIntent(shareIntent);
167         }
168         // END_INCLUDE(update_sap)
169     }
170 
171     /**
172      * A OnPageChangeListener used to update the ShareActionProvider's share intent when a new item
173      * is selected in the ViewPager.
174      */
175     private final ViewPager.OnPageChangeListener mOnPageChangeListener
176             = new ViewPager.OnPageChangeListener() {
177 
178         @Override
179         public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
180             // NO-OP
181         }
182 
183         @Override
184         public void onPageSelected(int position) {
185             setShareIntent(position);
186         }
187 
188         @Override
189         public void onPageScrollStateChanged(int state) {
190             // NO-OP
191         }
192     };
193 
194     /**
195      * @return An ArrayList of ContentItem's to be displayed in this sample
196      */
getSampleContent()197     static ArrayList<ContentItem> getSampleContent() {
198         ArrayList<ContentItem> items = new ArrayList<ContentItem>();
199 
200         items.add(new ContentItem(ContentItem.CONTENT_TYPE_IMAGE, "photo_1.jpg"));
201         items.add(new ContentItem(ContentItem.CONTENT_TYPE_TEXT, R.string.quote_1));
202         items.add(new ContentItem(ContentItem.CONTENT_TYPE_TEXT, R.string.quote_2));
203         items.add(new ContentItem(ContentItem.CONTENT_TYPE_IMAGE, "photo_2.jpg"));
204         items.add(new ContentItem(ContentItem.CONTENT_TYPE_TEXT, R.string.quote_3));
205         items.add(new ContentItem(ContentItem.CONTENT_TYPE_IMAGE, "photo_3.jpg"));
206 
207         return items;
208     }
209 
210 }