Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- package com.emanuelenberg.stormy;
- import android.content.Context;
- import android.graphics.drawable.Drawable;
- import android.net.ConnectivityManager;
- import android.net.NetworkInfo;
- import android.support.v7.app.AppCompatActivity;
- import android.os.Bundle;
- import android.util.Log;
- import android.view.View;
- import android.widget.ImageView;
- import android.widget.ProgressBar;
- import android.widget.TextView;
- import android.widget.Toast;
- import org.json.JSONException;
- import org.json.JSONObject;
- import java.io.IOException;
- import butterknife.BindView;
- import butterknife.ButterKnife;
- import okhttp3.Call;
- import okhttp3.Callback;
- import okhttp3.OkHttpClient;
- import okhttp3.Request;
- import okhttp3.Response;
- public class MainActivity extends AppCompatActivity {
- public static final String TAG = MainActivity.class.getSimpleName();
- private CurrentWeather mCurrentWeather;
- @BindView(R.id.timeLabel) TextView mTimeLabel;
- @BindView(R.id.temperatureValue) TextView mTemperatureValue;
- @BindView(R.id.humidityValue) TextView mHumidityValue;
- @BindView(R.id.precipValue) TextView mPrecipValue;
- @BindView(R.id.summaryLabel) TextView mSummaryLabel;
- @BindView(R.id.iconImageView) ImageView mIconImageView;
- @BindView(R.id.refreshImageView) ImageView mRefreshImageView;
- @BindView(R.id.progressBar) ProgressBar mProgressBar;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- ButterKnife.bind(this);
- mProgressBar.setVisibility(View.INVISIBLE);
- final double latitude = 37.8267;
- final double longitude = -122.423;
- mRefreshImageView.setOnClickListener(new View.OnClickListener() {
- @Override
- public void onClick(View v) {
- getForecast(latitude, longitude);
- }
- });
- getForecast(latitude, longitude);
- Log.d(TAG, "Main UI code is running");
- }
- private void getForecast(double latitude, double longitude) {
- String apiKey = "487df07849a9112c9454e8fc8e35787d";
- String forecastURL = ("https://api.forecast.io/forecast/" + apiKey + "/" + latitude + "," + longitude);
- if (isNetworkAvailable()) {
- toggleRefresh();
- OkHttpClient client = new OkHttpClient();
- Request request = new Request.Builder()
- .url(forecastURL)
- .build();
- Call call = client.newCall(request);
- call.enqueue(new Callback() {
- @Override
- public void onFailure(Call call, IOException e) {
- runOnUiThread(new Runnable() {
- @Override
- public void run() {
- toggleRefresh();
- }
- });
- alertUserAboutError();
- }
- @Override
- public void onResponse(Call call, Response response) throws IOException {
- runOnUiThread(new Runnable() {
- @Override
- public void run() {
- toggleRefresh();
- }
- });
- try {
- String jsonData = response.body().string();
- Log.v(TAG, jsonData);
- if (response.isSuccessful()) {
- mCurrentWeather = getCurrentDetails(jsonData);
- runOnUiThread(new Runnable() {
- @Override
- public void run() {
- updateDisplay();
- }
- });
- }else{
- alertUserAboutError();
- }
- } catch (IOException e) {
- Log.e(TAG, "Exception caught: ", e);
- } catch (JSONException e){
- Log.e(TAG, "Exception caught: ", e);
- }
- }
- });
- }else{
- Toast.makeText(this, R.string.network_unavailable_message, Toast.LENGTH_LONG).show();
- }
- }
- private void toggleRefresh() {
- if (mProgressBar.getVisibility() == View.INVISIBLE){
- mProgressBar.setVisibility(View.VISIBLE);
- mRefreshImageView.setVisibility(View.INVISIBLE);
- }else{
- mProgressBar.setVisibility(View.INVISIBLE);
- mRefreshImageView.setVisibility(View.VISIBLE);
- }
- }
- private void updateDisplay() {
- mTemperatureValue.setText(mCurrentWeather.getTemperatureInCelsius()+"");
- mTimeLabel.setText("At " + mCurrentWeather.getFormattedTime() + " it will be");
- mHumidityValue.setText(mCurrentWeather.getHumidity() +"");
- mPrecipValue.setText(mCurrentWeather.getPrecipChance() + "%");
- mSummaryLabel.setText(mCurrentWeather.getSummary());
- Drawable drawable = getResources().getDrawable(mCurrentWeather.getIconId());
- mIconImageView.setImageDrawable(drawable);
- }
- private CurrentWeather getCurrentDetails(String jsonData) throws JSONException {
- JSONObject forecast = new JSONObject(jsonData);
- JSONObject currently = forecast.getJSONObject("currently");
- CurrentWeather currentWeather = new CurrentWeather();
- currentWeather.setIcon(currently.getString("icon"));
- currentWeather.setTime(currently.getLong("time"));
- currentWeather.setTemperature(currently.getDouble("temperature"));
- currentWeather.setHumidity(currently.getDouble("humidity"));
- currentWeather.setPrecipChance(currently.getDouble("precipProbability"));
- currentWeather.setSummary(currently.getString("summary"));
- currentWeather.setTimezone(forecast.getString("timezone"));
- Log.d(TAG, currentWeather.getFormattedTime());
- return currentWeather;
- }
- private boolean isNetworkAvailable() {
- ConnectivityManager manager = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
- NetworkInfo networkInfo = manager.getActiveNetworkInfo();
- boolean isAvailable = false;
- if(networkInfo != null && networkInfo.isConnected()){
- isAvailable = true;
- }
- return isAvailable;
- }
- private void alertUserAboutError() {
- AlertDialogFragment dialog = new AlertDialogFragment();
- dialog.show(getFragmentManager(), "error_dialog");
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement