1*90c8c64dSAndroid Build Coastguard Worker /*
2*90c8c64dSAndroid Build Coastguard Worker * Copyright 2013 The Android Open Source Project
3*90c8c64dSAndroid Build Coastguard Worker *
4*90c8c64dSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
5*90c8c64dSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
6*90c8c64dSAndroid Build Coastguard Worker * You may obtain a copy of the License at
7*90c8c64dSAndroid Build Coastguard Worker *
8*90c8c64dSAndroid Build Coastguard Worker *     http://www.apache.org/licenses/LICENSE-2.0
9*90c8c64dSAndroid Build Coastguard Worker *
10*90c8c64dSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
11*90c8c64dSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
12*90c8c64dSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*90c8c64dSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
14*90c8c64dSAndroid Build Coastguard Worker * limitations under the License.
15*90c8c64dSAndroid Build Coastguard Worker */
16*90c8c64dSAndroid Build Coastguard Worker 
17*90c8c64dSAndroid Build Coastguard Worker 
18*90c8c64dSAndroid Build Coastguard Worker package com.example.android.swiperefreshlayoutbasic;
19*90c8c64dSAndroid Build Coastguard Worker 
20*90c8c64dSAndroid Build Coastguard Worker import android.os.Bundle;
21*90c8c64dSAndroid Build Coastguard Worker import android.support.v4.app.FragmentTransaction;
22*90c8c64dSAndroid Build Coastguard Worker import android.view.Menu;
23*90c8c64dSAndroid Build Coastguard Worker import android.view.MenuItem;
24*90c8c64dSAndroid Build Coastguard Worker import android.widget.ViewAnimator;
25*90c8c64dSAndroid Build Coastguard Worker 
26*90c8c64dSAndroid Build Coastguard Worker import com.example.android.common.activities.SampleActivityBase;
27*90c8c64dSAndroid Build Coastguard Worker import com.example.android.common.logger.Log;
28*90c8c64dSAndroid Build Coastguard Worker import com.example.android.common.logger.LogFragment;
29*90c8c64dSAndroid Build Coastguard Worker import com.example.android.common.logger.LogWrapper;
30*90c8c64dSAndroid Build Coastguard Worker import com.example.android.common.logger.MessageOnlyLogFilter;
31*90c8c64dSAndroid Build Coastguard Worker 
32*90c8c64dSAndroid Build Coastguard Worker /**
33*90c8c64dSAndroid Build Coastguard Worker  * A simple launcher activity containing a summary sample description, sample log and a custom
34*90c8c64dSAndroid Build Coastguard Worker  * {@link android.support.v4.app.Fragment} which can display a view.
35*90c8c64dSAndroid Build Coastguard Worker  * <p>
36*90c8c64dSAndroid Build Coastguard Worker  * For devices with displays with a width of 720dp or greater, the sample log is always visible,
37*90c8c64dSAndroid Build Coastguard Worker  * on other devices it's visibility is controlled by an item on the Action Bar.
38*90c8c64dSAndroid Build Coastguard Worker  */
39*90c8c64dSAndroid Build Coastguard Worker public class MainActivity extends SampleActivityBase {
40*90c8c64dSAndroid Build Coastguard Worker 
41*90c8c64dSAndroid Build Coastguard Worker     public static final String TAG = "MainActivity";
42*90c8c64dSAndroid Build Coastguard Worker 
43*90c8c64dSAndroid Build Coastguard Worker     // Whether the Log Fragment is currently shown
44*90c8c64dSAndroid Build Coastguard Worker     private boolean mLogShown;
45*90c8c64dSAndroid Build Coastguard Worker 
46*90c8c64dSAndroid Build Coastguard Worker     @Override
onCreate(Bundle savedInstanceState)47*90c8c64dSAndroid Build Coastguard Worker     protected void onCreate(Bundle savedInstanceState) {
48*90c8c64dSAndroid Build Coastguard Worker         super.onCreate(savedInstanceState);
49*90c8c64dSAndroid Build Coastguard Worker         setContentView(R.layout.activity_main);
50*90c8c64dSAndroid Build Coastguard Worker 
51*90c8c64dSAndroid Build Coastguard Worker         if (savedInstanceState == null) {
52*90c8c64dSAndroid Build Coastguard Worker             FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();
53*90c8c64dSAndroid Build Coastguard Worker             SwipeRefreshLayoutBasicFragment fragment = new SwipeRefreshLayoutBasicFragment();
54*90c8c64dSAndroid Build Coastguard Worker             transaction.replace(R.id.sample_content_fragment, fragment);
55*90c8c64dSAndroid Build Coastguard Worker             transaction.commit();
56*90c8c64dSAndroid Build Coastguard Worker         }
57*90c8c64dSAndroid Build Coastguard Worker     }
58*90c8c64dSAndroid Build Coastguard Worker 
59*90c8c64dSAndroid Build Coastguard Worker     @Override
onCreateOptionsMenu(Menu menu)60*90c8c64dSAndroid Build Coastguard Worker     public boolean onCreateOptionsMenu(Menu menu) {
61*90c8c64dSAndroid Build Coastguard Worker         getMenuInflater().inflate(R.menu.main, menu);
62*90c8c64dSAndroid Build Coastguard Worker         return true;
63*90c8c64dSAndroid Build Coastguard Worker     }
64*90c8c64dSAndroid Build Coastguard Worker 
65*90c8c64dSAndroid Build Coastguard Worker     @Override
onPrepareOptionsMenu(Menu menu)66*90c8c64dSAndroid Build Coastguard Worker     public boolean onPrepareOptionsMenu(Menu menu) {
67*90c8c64dSAndroid Build Coastguard Worker         MenuItem logToggle = menu.findItem(R.id.menu_toggle_log);
68*90c8c64dSAndroid Build Coastguard Worker         logToggle.setVisible(findViewById(R.id.sample_output) instanceof ViewAnimator);
69*90c8c64dSAndroid Build Coastguard Worker         logToggle.setTitle(mLogShown ? R.string.sample_hide_log : R.string.sample_show_log);
70*90c8c64dSAndroid Build Coastguard Worker 
71*90c8c64dSAndroid Build Coastguard Worker         return super.onPrepareOptionsMenu(menu);
72*90c8c64dSAndroid Build Coastguard Worker     }
73*90c8c64dSAndroid Build Coastguard Worker 
74*90c8c64dSAndroid Build Coastguard Worker     @Override
onOptionsItemSelected(MenuItem item)75*90c8c64dSAndroid Build Coastguard Worker     public boolean onOptionsItemSelected(MenuItem item) {
76*90c8c64dSAndroid Build Coastguard Worker         switch(item.getItemId()) {
77*90c8c64dSAndroid Build Coastguard Worker             case R.id.menu_toggle_log:
78*90c8c64dSAndroid Build Coastguard Worker                 mLogShown = !mLogShown;
79*90c8c64dSAndroid Build Coastguard Worker                 ViewAnimator output = (ViewAnimator) findViewById(R.id.sample_output);
80*90c8c64dSAndroid Build Coastguard Worker                 if (mLogShown) {
81*90c8c64dSAndroid Build Coastguard Worker                     output.setDisplayedChild(1);
82*90c8c64dSAndroid Build Coastguard Worker                 } else {
83*90c8c64dSAndroid Build Coastguard Worker                     output.setDisplayedChild(0);
84*90c8c64dSAndroid Build Coastguard Worker                 }
85*90c8c64dSAndroid Build Coastguard Worker                 supportInvalidateOptionsMenu();
86*90c8c64dSAndroid Build Coastguard Worker                 return true;
87*90c8c64dSAndroid Build Coastguard Worker         }
88*90c8c64dSAndroid Build Coastguard Worker         return super.onOptionsItemSelected(item);
89*90c8c64dSAndroid Build Coastguard Worker     }
90*90c8c64dSAndroid Build Coastguard Worker 
91*90c8c64dSAndroid Build Coastguard Worker     /** Create a chain of targets that will receive log data */
92*90c8c64dSAndroid Build Coastguard Worker     @Override
initializeLogging()93*90c8c64dSAndroid Build Coastguard Worker     public void initializeLogging() {
94*90c8c64dSAndroid Build Coastguard Worker         // Wraps Android's native log framework.
95*90c8c64dSAndroid Build Coastguard Worker         LogWrapper logWrapper = new LogWrapper();
96*90c8c64dSAndroid Build Coastguard Worker         // Using Log, front-end to the logging chain, emulates android.util.log method signatures.
97*90c8c64dSAndroid Build Coastguard Worker         Log.setLogNode(logWrapper);
98*90c8c64dSAndroid Build Coastguard Worker 
99*90c8c64dSAndroid Build Coastguard Worker         // Filter strips out everything except the message text.
100*90c8c64dSAndroid Build Coastguard Worker         MessageOnlyLogFilter msgFilter = new MessageOnlyLogFilter();
101*90c8c64dSAndroid Build Coastguard Worker         logWrapper.setNext(msgFilter);
102*90c8c64dSAndroid Build Coastguard Worker 
103*90c8c64dSAndroid Build Coastguard Worker         // On screen logging via a fragment with a TextView.
104*90c8c64dSAndroid Build Coastguard Worker         LogFragment logFragment = (LogFragment) getSupportFragmentManager()
105*90c8c64dSAndroid Build Coastguard Worker                 .findFragmentById(R.id.log_fragment);
106*90c8c64dSAndroid Build Coastguard Worker         msgFilter.setNext(logFragment.getLogView());
107*90c8c64dSAndroid Build Coastguard Worker 
108*90c8c64dSAndroid Build Coastguard Worker         Log.i(TAG, "Ready");
109*90c8c64dSAndroid Build Coastguard Worker     }
110*90c8c64dSAndroid Build Coastguard Worker }
111