From 3e6da9f19cd56bff8fee2dc8e8b42291714300ca Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tomasz=20P=C3=B3=C5=82grabia?= Date: Fri, 26 Aug 2016 21:55:33 +0200 Subject: [PATCH] Initial version of urban explorer. --- .gitignore | 9 + app/.gitignore | 1 + app/build.gradle | 28 +++ app/proguard-rules.pro | 17 ++ .../urbanexplorer/ApplicationTest.java | 13 ++ app/src/main/AndroidManifest.xml | 22 +++ .../urbanexplorer/MainActivity.java | 103 +++++++++++ .../urbanexplorer/fragments/HomeFragment.java | 64 +++++++ .../fragments/LoginFragment.java | 30 ++++ .../fragments/SettingsFragment.java | 30 ++++ app/src/main/res/layout-v21/activity_main.xml | 19 +++ app/src/main/res/layout/activity_main.xml | 26 +++ app/src/main/res/layout/fragment_home.xml | 14 ++ app/src/main/res/layout/fragment_login.xml | 53 ++++++ app/src/main/res/layout/fragment_settings.xml | 27 +++ app/src/main/res/menu/toolbar.xml | 6 + app/src/main/res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 3418 bytes app/src/main/res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 2206 bytes app/src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 4842 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 7718 bytes .../main/res/mipmap-xxxhdpi/ic_launcher.png | Bin 0 -> 10486 bytes app/src/main/res/values-w820dp/dimens.xml | 6 + app/src/main/res/values/dimens.xml | 6 + app/src/main/res/values/strings.xml | 14 ++ app/src/main/res/values/styles.xml | 8 + .../urbanexplorer/ExampleUnitTest.java | 15 ++ build.gradle | 23 +++ gradle.properties | 18 ++ gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 53637 bytes gradle/wrapper/gradle-wrapper.properties | 6 + gradlew | 160 ++++++++++++++++++ gradlew.bat | 90 ++++++++++ settings.gradle | 1 + 33 files changed, 809 insertions(+) create mode 100644 .gitignore create mode 100644 app/.gitignore create mode 100644 app/build.gradle create mode 100644 app/proguard-rules.pro create mode 100644 app/src/androidTest/java/pl/tpolgrabia/urbanexplorer/ApplicationTest.java create mode 100644 app/src/main/AndroidManifest.xml create mode 100644 app/src/main/java/pl/tpolgrabia/urbanexplorer/MainActivity.java create mode 100644 app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/HomeFragment.java create mode 100644 app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/LoginFragment.java create mode 100644 app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/SettingsFragment.java create mode 100644 app/src/main/res/layout-v21/activity_main.xml create mode 100644 app/src/main/res/layout/activity_main.xml create mode 100644 app/src/main/res/layout/fragment_home.xml create mode 100644 app/src/main/res/layout/fragment_login.xml create mode 100644 app/src/main/res/layout/fragment_settings.xml create mode 100644 app/src/main/res/menu/toolbar.xml create mode 100644 app/src/main/res/mipmap-hdpi/ic_launcher.png create mode 100644 app/src/main/res/mipmap-mdpi/ic_launcher.png create mode 100644 app/src/main/res/mipmap-xhdpi/ic_launcher.png create mode 100644 app/src/main/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 app/src/main/res/mipmap-xxxhdpi/ic_launcher.png create mode 100644 app/src/main/res/values-w820dp/dimens.xml create mode 100644 app/src/main/res/values/dimens.xml create mode 100644 app/src/main/res/values/strings.xml create mode 100644 app/src/main/res/values/styles.xml create mode 100644 app/src/test/java/pl/tpolgrabia/urbanexplorer/ExampleUnitTest.java create mode 100644 build.gradle create mode 100644 gradle.properties create mode 100644 gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/wrapper/gradle-wrapper.properties create mode 100755 gradlew create mode 100644 gradlew.bat create mode 100644 settings.gradle diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..31f01ae --- /dev/null +++ b/.gitignore @@ -0,0 +1,9 @@ +*.iml +.gradle +/local.properties +/.idea/workspace.xml +/.idea/libraries +.DS_Store +/build +/captures +.idea diff --git a/app/.gitignore b/app/.gitignore new file mode 100644 index 0000000..796b96d --- /dev/null +++ b/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/app/build.gradle b/app/build.gradle new file mode 100644 index 0000000..5065fda --- /dev/null +++ b/app/build.gradle @@ -0,0 +1,28 @@ +apply plugin: 'com.android.application' + +android { + compileSdkVersion 21 + buildToolsVersion "23.0.3" + + defaultConfig { + applicationId "pl.tpolgrabia.urbanexplorer" + minSdkVersion 21 + targetSdkVersion 21 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } +} + +dependencies { + compile fileTree(dir: 'libs', include: ['*.jar']) + testCompile 'junit:junit:4.12' + compile 'com.android.support:appcompat-v7:21.0.3' + compile 'com.android.support:support-v4:21.0.3' + compile 'com.android.support:recyclerview-v7:21.0.3' +} diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro new file mode 100644 index 0000000..f253a1f --- /dev/null +++ b/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in /home/tpolgrabia/bin/android-sdk-linux/tools/proguard/proguard-android.txt +# You can edit the include path and order by changing the proguardFiles +# directive in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# Add any project specific keep options here: + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} diff --git a/app/src/androidTest/java/pl/tpolgrabia/urbanexplorer/ApplicationTest.java b/app/src/androidTest/java/pl/tpolgrabia/urbanexplorer/ApplicationTest.java new file mode 100644 index 0000000..75cbedc --- /dev/null +++ b/app/src/androidTest/java/pl/tpolgrabia/urbanexplorer/ApplicationTest.java @@ -0,0 +1,13 @@ +package pl.tpolgrabia.urbanexplorer; + +import android.app.Application; +import android.test.ApplicationTestCase; + +/** + * Testing Fundamentals + */ +public class ApplicationTest extends ApplicationTestCase { + public ApplicationTest() { + super(Application.class); + } +} \ No newline at end of file diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..32e23bc --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + diff --git a/app/src/main/java/pl/tpolgrabia/urbanexplorer/MainActivity.java b/app/src/main/java/pl/tpolgrabia/urbanexplorer/MainActivity.java new file mode 100644 index 0000000..51c65fb --- /dev/null +++ b/app/src/main/java/pl/tpolgrabia/urbanexplorer/MainActivity.java @@ -0,0 +1,103 @@ +package pl.tpolgrabia.urbanexplorer; + +import android.content.Intent; +import android.location.LocationManager; +import android.os.Bundle; +import android.provider.Settings; +import android.support.v7.app.ActionBarActivity; +import android.support.v7.widget.Toolbar; +import android.view.MenuItem; +import android.widget.Toast; +import pl.tpolgrabia.urbanexplorer.fragments.HomeFragment; + +public class MainActivity extends ActionBarActivity { + + private static final int LOCATION_SETTINGS_REQUEST_ID = 1; + private static final String CLASS_TAG = MainActivity.class.getSimpleName(); + private static final long MIN_TIME = 60000; + private static final float MIN_DISTANCE = 100; + private boolean gpsLocationEnabled; + private boolean networkLocationEnabled; + private boolean locationEnabled; + private LocationManager locationService; + private String locationProvider; + private HomeFragment homeFrag; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_main); + Toolbar toolbar = (Toolbar) findViewById(R.id.navbar); + setSupportActionBar(toolbar); + + locationService = (LocationManager) getSystemService(LOCATION_SERVICE); + checkLocationSourceAvailability(); + + if (!locationEnabled) { + Intent locationSettingsIntent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS); + startActivityForResult(locationSettingsIntent, LOCATION_SETTINGS_REQUEST_ID); + } + + } + + @Override + protected void onResume() { + super.onResume(); + + homeFrag = (HomeFragment) getSupportFragmentManager().findFragmentById(R.id.home); + locationService.requestLocationUpdates(locationProvider, + MIN_TIME, + MIN_DISTANCE, + homeFrag); + } + + @Override + protected void onPause() { + super.onPause(); + locationService.removeUpdates(homeFrag); + } + + @Override + protected void onActivityResult(int requestCode, int resultCode, Intent data) { + + switch (requestCode) { + case LOCATION_SETTINGS_REQUEST_ID: + checkLocationSourceAvailability(); + if (!locationEnabled) { + // sadly, nothing to do except from notifing user that program is not enable working + Toast.makeText(this, "Sorry location services are not working." + + " Program cannot work properly - check location settings to allow program working correctly", + Toast.LENGTH_LONG); + } + break; + default: + super.onActivityResult(requestCode, resultCode, data); + } + } + + private void checkLocationSourceAvailability() { + gpsLocationEnabled = locationService.isProviderEnabled(LocationManager.GPS_PROVIDER); + networkLocationEnabled = locationService.isProviderEnabled(LocationManager.NETWORK_PROVIDER); + locationEnabled = gpsLocationEnabled || networkLocationEnabled; + if (gpsLocationEnabled) { + locationProvider = LocationManager.GPS_PROVIDER; + return; + } + + if (networkLocationEnabled) { + locationProvider = LocationManager.NETWORK_PROVIDER; + return; + } + } + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + switch (item.getItemId()) { + case R.id.settings: + // TODO show settings fragment + return true; + default: + return super.onOptionsItemSelected(item); + } + } +} diff --git a/app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/HomeFragment.java b/app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/HomeFragment.java new file mode 100644 index 0000000..1194ffe --- /dev/null +++ b/app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/HomeFragment.java @@ -0,0 +1,64 @@ +package pl.tpolgrabia.urbanexplorer.fragments; + + +import android.location.Location; +import android.location.LocationListener; +import android.os.Bundle; +import android.support.v4.app.Fragment; +import android.util.Log; +import android.view.LayoutInflater; +import android.view.View; +import android.view.ViewGroup; + +import android.widget.TextView; +import pl.tpolgrabia.urbanexplorer.R; + +/** + * A simple {@link Fragment} subclass. + */ +public class HomeFragment extends Fragment implements LocationListener { + + private static final String CLASS_TAG = HomeFragment.class.getSimpleName(); + + public HomeFragment() { + // Required empty public constructor + } + + @Override + public View onCreateView(LayoutInflater inflater, ViewGroup container, + Bundle savedInstanceState) { + // Inflate the layout for this fragment + return inflater.inflate(R.layout.fragment_home, container, false); + } + + public void setLocationData(double lat, double lng) { + TextView locationInfo = (TextView) getActivity().findViewById(R.id.locationInfo); + locationInfo.setText("Location: (" + lat + "," + lng + ")"); + } + + @Override + public void onLocationChanged(Location location) { + Log.i(CLASS_TAG, "Location provider changed: " + location); + double lat = location.getLatitude(); + double lng = location.getLongitude(); + HomeFragment homeFrag = (HomeFragment) getActivity() + .getSupportFragmentManager() + .findFragmentById(R.id.home); + homeFrag.setLocationData(lat, lng); + } + + @Override + public void onStatusChanged(String provider, int status, Bundle extras) { + // Log.i(CLASS_TAG, "Location provider status changed") + } + + @Override + public void onProviderEnabled(String provider) { + Log.i(CLASS_TAG, "Provider " + provider + " enabled"); + } + + @Override + public void onProviderDisabled(String provider) { + Log.i(CLASS_TAG, "Provider " + provider + " disabled"); + } +} diff --git a/app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/LoginFragment.java b/app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/LoginFragment.java new file mode 100644 index 0000000..910f173 --- /dev/null +++ b/app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/LoginFragment.java @@ -0,0 +1,30 @@ +package pl.tpolgrabia.urbanexplorer.fragments; + + +import android.os.Bundle; +import android.support.v4.app.Fragment; +import android.view.LayoutInflater; +import android.view.View; +import android.view.ViewGroup; + +import pl.tpolgrabia.urbanexplorer.R; + +/** + * A simple {@link Fragment} subclass. + */ +public class LoginFragment extends Fragment { + + + public LoginFragment() { + // Required empty public constructor + } + + + @Override + public View onCreateView(LayoutInflater inflater, ViewGroup container, + Bundle savedInstanceState) { + // Inflate the layout for this fragment + return inflater.inflate(R.layout.fragment_login, container, false); + } + +} diff --git a/app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/SettingsFragment.java b/app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/SettingsFragment.java new file mode 100644 index 0000000..194f62b --- /dev/null +++ b/app/src/main/java/pl/tpolgrabia/urbanexplorer/fragments/SettingsFragment.java @@ -0,0 +1,30 @@ +package pl.tpolgrabia.urbanexplorer.fragments; + + +import android.os.Bundle; +import android.support.v4.app.Fragment; +import android.view.LayoutInflater; +import android.view.View; +import android.view.ViewGroup; + +import pl.tpolgrabia.urbanexplorer.R; + +/** + * A simple {@link Fragment} subclass. + */ +public class SettingsFragment extends Fragment { + + + public SettingsFragment() { + // Required empty public constructor + } + + + @Override + public View onCreateView(LayoutInflater inflater, ViewGroup container, + Bundle savedInstanceState) { + // Inflate the layout for this fragment + return inflater.inflate(R.layout.fragment_settings, container, false); + } + +} diff --git a/app/src/main/res/layout-v21/activity_main.xml b/app/src/main/res/layout-v21/activity_main.xml new file mode 100644 index 0000000..0c8a795 --- /dev/null +++ b/app/src/main/res/layout-v21/activity_main.xml @@ -0,0 +1,19 @@ + + + + + + + + diff --git a/app/src/main/res/layout/activity_main.xml b/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000..8b70d69 --- /dev/null +++ b/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,26 @@ + + + + + + + + + + diff --git a/app/src/main/res/layout/fragment_home.xml b/app/src/main/res/layout/fragment_home.xml new file mode 100644 index 0000000..94f3953 --- /dev/null +++ b/app/src/main/res/layout/fragment_home.xml @@ -0,0 +1,14 @@ + + + + + + diff --git a/app/src/main/res/layout/fragment_login.xml b/app/src/main/res/layout/fragment_login.xml new file mode 100644 index 0000000..3426b47 --- /dev/null +++ b/app/src/main/res/layout/fragment_login.xml @@ -0,0 +1,53 @@ + + + + + + + + + + + + + + + + + + + + + +