Home | History | Annotate | Download | only in com.example.android.shareactionprovider
      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.shareactionprovider;
     18 
     19 import com.example.android.shareactionprovider.content.ContentItem;
     20 
     21 import android.content.Intent;
     22 import android.os.Bundle;
     23 import android.support.v4.view.MenuItemCompat;
     24 import android.support.v4.view.PagerAdapter;
     25 import android.support.v4.view.ViewPager;
     26 import android.support.v7.app.AppCompatActivity;
     27 import android.support.v7.widget.ShareActionProvider;
     28 import android.view.LayoutInflater;
     29 import android.view.Menu;
     30 import android.view.MenuItem;
     31 import android.view.View;
     32 import android.view.ViewGroup;
     33 import android.widget.ImageView;
     34 import android.widget.TextView;
     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  */
     47 public class MainActivity extends AppCompatActivity {
     48 
     49     // The items to be displayed in the ViewPager
     50     private final ArrayList<ContentItem> mItems = getSampleContent();
     51 
     52     // Keep reference to the ShareActionProvider from the menu
     53     private ShareActionProvider mShareActionProvider;
     54 
     55     @Override
     56     protected void onCreate(Bundle savedInstanceState) {
     57         super.onCreate(savedInstanceState);
     58 
     59         // Set content view (which contains a CheeseListFragment)
     60         setContentView(R.layout.sample_main);
     61 
     62         // Retrieve the ViewPager from the content view
     63         ViewPager vp = (ViewPager) findViewById(R.id.viewpager);
     64 
     65         // Set an OnPageChangeListener so we are notified when a new item is selected
     66         vp.addOnPageChangeListener(mOnPageChangeListener);
     67 
     68         // Finally set the adapter so the ViewPager can display items
     69         vp.setAdapter(mPagerAdapter);
     70     }
     71 
     72     // BEGIN_INCLUDE(get_sap)
     73     @Override
     74     public boolean onCreateOptionsMenu(Menu menu) {
     75         // Inflate the menu resource
     76         getMenuInflater().inflate(R.menu.main_menu, menu);
     77 
     78         // Retrieve the share menu item
     79         MenuItem shareItem = menu.findItem(R.id.menu_share);
     80 
     81         // Now get the ShareActionProvider from the item
     82         mShareActionProvider = (ShareActionProvider) MenuItemCompat.getActionProvider(shareItem);
     83 
     84         // Get the ViewPager's current item position and set its ShareIntent.
     85         int currentViewPagerItem = ((ViewPager) findViewById(R.id.viewpager)).getCurrentItem();
     86         setShareIntent(currentViewPagerItem);
     87 
     88         return super.onCreateOptionsMenu(menu);
     89     }
     90     // END_INCLUDE(get_sap)
     91 
     92     /**
     93      * A PagerAdapter which instantiates views based on the ContentItem's content type.
     94      */
     95     private final PagerAdapter mPagerAdapter = new PagerAdapter() {
     96         LayoutInflater mInflater;
     97 
     98         @Override
     99         public int getCount() {
    100             return mItems.size();
    101         }
    102 
    103         @Override
    104         public boolean isViewFromObject(View view, Object o) {
    105             return view == o;
    106         }
    107 
    108         @Override
    109         public void destroyItem(ViewGroup container, int position, Object object) {
    110             // Just remove the view from the ViewPager
    111             container.removeView((View) object);
    112         }
    113 
    114         @Override
    115         public Object instantiateItem(ViewGroup container, int position) {
    116             // Ensure that the LayoutInflater is instantiated
    117             if (mInflater == null) {
    118                 mInflater = LayoutInflater.from(MainActivity.this);
    119             }
    120 
    121             // Get the item for the requested position
    122             final ContentItem item = mItems.get(position);
    123 
    124             // The view we need to inflate changes based on the type of content
    125             switch (item.contentType) {
    126                 case ContentItem.CONTENT_TYPE_TEXT: {
    127                     // Inflate item layout for text
    128                     TextView tv = (TextView) mInflater
    129                             .inflate(R.layout.item_text, container, false);
    130 
    131                     // Set text content using it's resource id
    132                     tv.setText(item.contentResourceId);
    133 
    134                     // Add the view to the ViewPager
    135                     container.addView(tv);
    136                     return tv;
    137                 }
    138                 case ContentItem.CONTENT_TYPE_IMAGE: {
    139                     // Inflate item layout for images
    140                     ImageView iv = (ImageView) mInflater
    141                             .inflate(R.layout.item_image, container, false);
    142 
    143                     // Load the image from it's content URI
    144                     iv.setImageURI(item.getContentUri());
    145 
    146                     // Add the view to the ViewPager
    147                     container.addView(iv);
    148                     return iv;
    149                 }
    150             }
    151 
    152             return null;
    153         }
    154     };
    155 
    156     private void setShareIntent(int position) {
    157         // BEGIN_INCLUDE(update_sap)
    158         if (mShareActionProvider != null) {
    159             // Get the currently selected item, and retrieve it's share intent
    160             ContentItem item = mItems.get(position);
    161             Intent shareIntent = item.getShareIntent(MainActivity.this);
    162 
    163             // Now update the ShareActionProvider with the new share intent
    164             mShareActionProvider.setShareIntent(shareIntent);
    165         }
    166         // END_INCLUDE(update_sap)
    167     }
    168 
    169     /**
    170      * A OnPageChangeListener used to update the ShareActionProvider's share intent when a new item
    171      * is selected in the ViewPager.
    172      */
    173     private final ViewPager.OnPageChangeListener mOnPageChangeListener
    174             = new ViewPager.OnPageChangeListener() {
    175 
    176         @Override
    177         public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
    178             // NO-OP
    179         }
    180 
    181         @Override
    182         public void onPageSelected(int position) {
    183             setShareIntent(position);
    184         }
    185 
    186         @Override
    187         public void onPageScrollStateChanged(int state) {
    188             // NO-OP
    189         }
    190     };
    191 
    192     /**
    193      * @return An ArrayList of ContentItem's to be displayed in this sample
    194      */
    195     static ArrayList<ContentItem> getSampleContent() {
    196         ArrayList<ContentItem> items = new ArrayList<ContentItem>();
    197 
    198         items.add(new ContentItem(ContentItem.CONTENT_TYPE_IMAGE, "photo_1.jpg"));
    199         items.add(new ContentItem(ContentItem.CONTENT_TYPE_TEXT, R.string.quote_1));
    200         items.add(new ContentItem(ContentItem.CONTENT_TYPE_TEXT, R.string.quote_2));
    201         items.add(new ContentItem(ContentItem.CONTENT_TYPE_IMAGE, "photo_2.jpg"));
    202         items.add(new ContentItem(ContentItem.CONTENT_TYPE_TEXT, R.string.quote_3));
    203         items.add(new ContentItem(ContentItem.CONTENT_TYPE_IMAGE, "photo_3.jpg"));
    204 
    205         return items;
    206     }
    207 
    208 }