blob: cbec157e4c31e4f6c42373305d519689549939c5 [file] [log] [blame]
Trevor Johns684d2c12014-10-16 02:54:51 -07001/*
2* Copyright 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
Trevor Johns818bd7c2015-05-20 22:03:03 -070017
Trevor Johns684d2c12014-10-16 02:54:51 -070018package com.example.android.swiperefreshlistfragment;
19
20import android.os.Bundle;
21import android.support.v4.app.FragmentTransaction;
22import android.view.Menu;
23import android.view.MenuItem;
24import android.widget.ViewAnimator;
25
26import com.example.android.common.activities.SampleActivityBase;
27import com.example.android.common.logger.Log;
28import com.example.android.common.logger.LogFragment;
29import com.example.android.common.logger.LogWrapper;
30import com.example.android.common.logger.MessageOnlyLogFilter;
31
32/**
33 * A simple launcher activity containing a summary sample description, sample log and a custom
34 * {@link android.support.v4.app.Fragment} which can display a view.
35 * <p>
36 * For devices with displays with a width of 720dp or greater, the sample log is always visible,
37 * on other devices it's visibility is controlled by an item on the Action Bar.
38 */
39public class MainActivity extends SampleActivityBase {
40
41 public static final String TAG = "MainActivity";
42
43 // Whether the Log Fragment is currently shown
44 private boolean mLogShown;
45
46 @Override
47 protected void onCreate(Bundle savedInstanceState) {
48 super.onCreate(savedInstanceState);
49 setContentView(R.layout.activity_main);
50
51 if (savedInstanceState == null) {
52 FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();
53 SwipeRefreshListFragmentFragment fragment = new SwipeRefreshListFragmentFragment();
54 transaction.replace(R.id.sample_content_fragment, fragment);
55 transaction.commit();
56 }
57 }
58
59 @Override
60 public boolean onCreateOptionsMenu(Menu menu) {
61 getMenuInflater().inflate(R.menu.main, menu);
62 return true;
63 }
64
65 @Override
66 public boolean onPrepareOptionsMenu(Menu menu) {
67 MenuItem logToggle = menu.findItem(R.id.menu_toggle_log);
68 logToggle.setVisible(findViewById(R.id.sample_output) instanceof ViewAnimator);
69 logToggle.setTitle(mLogShown ? R.string.sample_hide_log : R.string.sample_show_log);
70
71 return super.onPrepareOptionsMenu(menu);
72 }
73
74 @Override
75 public boolean onOptionsItemSelected(MenuItem item) {
76 switch(item.getItemId()) {
77 case R.id.menu_toggle_log:
78 mLogShown = !mLogShown;
79 ViewAnimator output = (ViewAnimator) findViewById(R.id.sample_output);
80 if (mLogShown) {
81 output.setDisplayedChild(1);
82 } else {
83 output.setDisplayedChild(0);
84 }
85 supportInvalidateOptionsMenu();
86 return true;
87 }
88 return super.onOptionsItemSelected(item);
89 }
90
91 /** Create a chain of targets that will receive log data */
92 @Override
93 public void initializeLogging() {
94 // Wraps Android's native log framework.
95 LogWrapper logWrapper = new LogWrapper();
96 // Using Log, front-end to the logging chain, emulates android.util.log method signatures.
97 Log.setLogNode(logWrapper);
98
99 // Filter strips out everything except the message text.
100 MessageOnlyLogFilter msgFilter = new MessageOnlyLogFilter();
101 logWrapper.setNext(msgFilter);
102
103 // On screen logging via a fragment with a TextView.
104 LogFragment logFragment = (LogFragment) getSupportFragmentManager()
105 .findFragmentById(R.id.log_fragment);
106 msgFilter.setNext(logFragment.getLogView());
107
108 Log.i(TAG, "Ready");
109 }
110}