Skip to content

Most visited

Recently visited

navigation
ShareActionProvider / src / com.example.android.shareactionprovider /

MainActivity.java

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
 
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
    }
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) {
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
        }
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
}
This site uses cookies to store your preferences for site-specific language and display options.

Hooray!