• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
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 
17 package com.example.android.networkconnect;
18 
19 import android.os.AsyncTask;
20 import android.os.Bundle;
21 import android.support.v4.app.FragmentActivity;
22 import android.util.TypedValue;
23 import android.view.Menu;
24 import android.view.MenuItem;
25 
26 import com.example.android.common.logger.Log;
27 import com.example.android.common.logger.LogFragment;
28 import com.example.android.common.logger.LogWrapper;
29 import com.example.android.common.logger.MessageOnlyLogFilter;
30 
31 import java.io.IOException;
32 import java.io.InputStream;
33 import java.io.InputStreamReader;
34 import java.io.Reader;
35 import java.io.UnsupportedEncodingException;
36 import java.net.HttpURLConnection;
37 import java.net.URL;
38 
39 /**
40  * Sample application demonstrating how to connect to the network and fetch raw
41  * HTML. It uses AsyncTask to do the fetch on a background thread. To establish
42  * the network connection, it uses HttpURLConnection.
43  *
44  * This sample uses the logging framework to display log output in the log
45  * fragment (LogFragment).
46  */
47 public class MainActivity extends FragmentActivity {
48 
49     public static final String TAG = "Network Connect";
50 
51     // Reference to the fragment showing events, so we can clear it with a button
52     // as necessary.
53     private LogFragment mLogFragment;
54 
55     @Override
onCreate(Bundle savedInstanceState)56     protected void onCreate(Bundle savedInstanceState) {
57         super.onCreate(savedInstanceState);
58         setContentView(R.layout.sample_main);
59 
60         // Initialize text fragment that displays intro text.
61         SimpleTextFragment introFragment = (SimpleTextFragment)
62                     getSupportFragmentManager().findFragmentById(R.id.intro_fragment);
63         introFragment.setText(R.string.welcome_message);
64         introFragment.getTextView().setTextSize(TypedValue.COMPLEX_UNIT_DIP, 16.0f);
65 
66         // Initialize the logging framework.
67         initializeLogging();
68     }
69 
70     @Override
onCreateOptionsMenu(Menu menu)71     public boolean onCreateOptionsMenu(Menu menu) {
72         getMenuInflater().inflate(R.menu.main, menu);
73         return true;
74     }
75 
76     @Override
onOptionsItemSelected(MenuItem item)77     public boolean onOptionsItemSelected(MenuItem item) {
78         switch (item.getItemId()) {
79             // When the user clicks FETCH, fetch the first 500 characters of
80             // raw HTML from www.google.com.
81             case R.id.fetch_action:
82                 new DownloadTask().execute("http://www.google.com");
83                 return true;
84             // Clear the log view fragment.
85             case R.id.clear_action:
86               mLogFragment.getLogView().setText("");
87               return true;
88         }
89         return false;
90     }
91 
92     /**
93      * Implementation of AsyncTask, to fetch the data in the background away from
94      * the UI thread.
95      */
96     private class DownloadTask extends AsyncTask<String, Void, String> {
97 
98         @Override
doInBackground(String... urls)99         protected String doInBackground(String... urls) {
100             try {
101                 return loadFromNetwork(urls[0]);
102             } catch (IOException e) {
103               return getString(R.string.connection_error);
104             }
105         }
106 
107         /**
108          * Uses the logging framework to display the output of the fetch
109          * operation in the log fragment.
110          */
111         @Override
onPostExecute(String result)112         protected void onPostExecute(String result) {
113           Log.i(TAG, result);
114         }
115     }
116 
117     /** Initiates the fetch operation. */
loadFromNetwork(String urlString)118     private String loadFromNetwork(String urlString) throws IOException {
119         InputStream stream = null;
120         String str ="";
121 
122         try {
123             stream = downloadUrl(urlString);
124             str = readIt(stream, 500);
125        } finally {
126            if (stream != null) {
127                stream.close();
128             }
129         }
130         return str;
131     }
132 
133     /**
134      * Given a string representation of a URL, sets up a connection and gets
135      * an input stream.
136      * @param urlString A string representation of a URL.
137      * @return An InputStream retrieved from a successful HttpURLConnection.
138      * @throws java.io.IOException
139      */
downloadUrl(String urlString)140     private InputStream downloadUrl(String urlString) throws IOException {
141         // BEGIN_INCLUDE(get_inputstream)
142         URL url = new URL(urlString);
143         HttpURLConnection conn = (HttpURLConnection) url.openConnection();
144         conn.setReadTimeout(10000 /* milliseconds */);
145         conn.setConnectTimeout(15000 /* milliseconds */);
146         conn.setRequestMethod("GET");
147         conn.setDoInput(true);
148         // Start the query
149         conn.connect();
150         InputStream stream = conn.getInputStream();
151         return stream;
152         // END_INCLUDE(get_inputstream)
153     }
154 
155     /** Reads an InputStream and converts it to a String.
156      * @param stream InputStream containing HTML from targeted site.
157      * @param len Length of string that this method returns.
158      * @return String concatenated according to len parameter.
159      * @throws java.io.IOException
160      * @throws java.io.UnsupportedEncodingException
161      */
readIt(InputStream stream, int len)162     private String readIt(InputStream stream, int len) throws IOException, UnsupportedEncodingException {
163         Reader reader = null;
164         reader = new InputStreamReader(stream, "UTF-8");
165         char[] buffer = new char[len];
166         reader.read(buffer);
167         return new String(buffer);
168     }
169 
170     /** Create a chain of targets that will receive log data */
initializeLogging()171     public void initializeLogging() {
172 
173         // Using Log, front-end to the logging chain, emulates
174         // android.util.log method signatures.
175 
176         // Wraps Android's native log framework
177         LogWrapper logWrapper = new LogWrapper();
178         Log.setLogNode(logWrapper);
179 
180         // A filter that strips out everything except the message text.
181         MessageOnlyLogFilter msgFilter = new MessageOnlyLogFilter();
182         logWrapper.setNext(msgFilter);
183 
184         // On screen logging via a fragment with a TextView.
185         mLogFragment =
186                 (LogFragment) getSupportFragmentManager().findFragmentById(R.id.log_fragment);
187         msgFilter.setNext(mLogFragment.getLogView());
188     }
189 }
190