Showing
54 changed files
with
2120 additions
and
0 deletions
.DS_Store
0 → 100644
No preview for this file type
Androidstudy_Project.zip
0 → 100644
This file is too large to display.
Androidstudy_Project/.gitignore
0 → 100755
No preview for this file type
| 1 | +<component name="ProjectCodeStyleConfiguration"> | ||
| 2 | + <code_scheme name="Project" version="173"> | ||
| 3 | + <Objective-C-extensions> | ||
| 4 | + <file> | ||
| 5 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="Import" /> | ||
| 6 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="Macro" /> | ||
| 7 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="Typedef" /> | ||
| 8 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="Enum" /> | ||
| 9 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="Constant" /> | ||
| 10 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="Global" /> | ||
| 11 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="Struct" /> | ||
| 12 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="FunctionPredecl" /> | ||
| 13 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="Function" /> | ||
| 14 | + </file> | ||
| 15 | + <class> | ||
| 16 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="Property" /> | ||
| 17 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="Synthesize" /> | ||
| 18 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="InitMethod" /> | ||
| 19 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="StaticMethod" /> | ||
| 20 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="InstanceMethod" /> | ||
| 21 | + <option name="com.jetbrains.cidr.lang.util.OCDeclarationKind" value="DeallocMethod" /> | ||
| 22 | + </class> | ||
| 23 | + <extensions> | ||
| 24 | + <pair source="cpp" header="h" fileNamingConvention="NONE" /> | ||
| 25 | + <pair source="c" header="h" fileNamingConvention="NONE" /> | ||
| 26 | + </extensions> | ||
| 27 | + </Objective-C-extensions> | ||
| 28 | + </code_scheme> | ||
| 29 | +</component> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
Androidstudy_Project/.idea/gradle.xml
0 → 100755
| 1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
| 2 | +<project version="4"> | ||
| 3 | + <component name="GradleSettings"> | ||
| 4 | + <option name="linkedExternalProjectsSettings"> | ||
| 5 | + <GradleProjectSettings> | ||
| 6 | + <compositeConfiguration> | ||
| 7 | + <compositeBuild compositeDefinitionSource="SCRIPT" /> | ||
| 8 | + </compositeConfiguration> | ||
| 9 | + <option name="distributionType" value="DEFAULT_WRAPPED" /> | ||
| 10 | + <option name="externalProjectPath" value="$PROJECT_DIR$" /> | ||
| 11 | + <option name="modules"> | ||
| 12 | + <set> | ||
| 13 | + <option value="$PROJECT_DIR$" /> | ||
| 14 | + <option value="$PROJECT_DIR$/app" /> | ||
| 15 | + </set> | ||
| 16 | + </option> | ||
| 17 | + <option name="resolveModulePerSourceSet" value="false" /> | ||
| 18 | + </GradleProjectSettings> | ||
| 19 | + </option> | ||
| 20 | + </component> | ||
| 21 | +</project> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
Androidstudy_Project/.idea/misc.xml
0 → 100755
| 1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
| 2 | +<project version="4"> | ||
| 3 | + <component name="NullableNotNullManager"> | ||
| 4 | + <option name="myDefaultNullable" value="android.support.annotation.Nullable" /> | ||
| 5 | + <option name="myDefaultNotNull" value="android.support.annotation.NonNull" /> | ||
| 6 | + <option name="myNullables"> | ||
| 7 | + <value> | ||
| 8 | + <list size="10"> | ||
| 9 | + <item index="0" class="java.lang.String" itemvalue="org.jetbrains.annotations.Nullable" /> | ||
| 10 | + <item index="1" class="java.lang.String" itemvalue="javax.annotation.Nullable" /> | ||
| 11 | + <item index="2" class="java.lang.String" itemvalue="javax.annotation.CheckForNull" /> | ||
| 12 | + <item index="3" class="java.lang.String" itemvalue="edu.umd.cs.findbugs.annotations.Nullable" /> | ||
| 13 | + <item index="4" class="java.lang.String" itemvalue="android.support.annotation.Nullable" /> | ||
| 14 | + <item index="5" class="java.lang.String" itemvalue="androidx.annotation.Nullable" /> | ||
| 15 | + <item index="6" class="java.lang.String" itemvalue="androidx.annotation.RecentlyNullable" /> | ||
| 16 | + <item index="7" class="java.lang.String" itemvalue="org.checkerframework.checker.nullness.qual.Nullable" /> | ||
| 17 | + <item index="8" class="java.lang.String" itemvalue="org.checkerframework.checker.nullness.compatqual.NullableDecl" /> | ||
| 18 | + <item index="9" class="java.lang.String" itemvalue="org.checkerframework.checker.nullness.compatqual.NullableType" /> | ||
| 19 | + </list> | ||
| 20 | + </value> | ||
| 21 | + </option> | ||
| 22 | + <option name="myNotNulls"> | ||
| 23 | + <value> | ||
| 24 | + <list size="9"> | ||
| 25 | + <item index="0" class="java.lang.String" itemvalue="org.jetbrains.annotations.NotNull" /> | ||
| 26 | + <item index="1" class="java.lang.String" itemvalue="javax.annotation.Nonnull" /> | ||
| 27 | + <item index="2" class="java.lang.String" itemvalue="edu.umd.cs.findbugs.annotations.NonNull" /> | ||
| 28 | + <item index="3" class="java.lang.String" itemvalue="android.support.annotation.NonNull" /> | ||
| 29 | + <item index="4" class="java.lang.String" itemvalue="androidx.annotation.NonNull" /> | ||
| 30 | + <item index="5" class="java.lang.String" itemvalue="androidx.annotation.RecentlyNonNull" /> | ||
| 31 | + <item index="6" class="java.lang.String" itemvalue="org.checkerframework.checker.nullness.qual.NonNull" /> | ||
| 32 | + <item index="7" class="java.lang.String" itemvalue="org.checkerframework.checker.nullness.compatqual.NonNullDecl" /> | ||
| 33 | + <item index="8" class="java.lang.String" itemvalue="org.checkerframework.checker.nullness.compatqual.NonNullType" /> | ||
| 34 | + </list> | ||
| 35 | + </value> | ||
| 36 | + </option> | ||
| 37 | + </component> | ||
| 38 | + <component name="ProjectRootManager" version="2" languageLevel="JDK_1_7" project-jdk-name="1.8" project-jdk-type="JavaSDK"> | ||
| 39 | + <output url="file://$PROJECT_DIR$/build/classes" /> | ||
| 40 | + </component> | ||
| 41 | + <component name="ProjectType"> | ||
| 42 | + <option name="id" value="Android" /> | ||
| 43 | + </component> | ||
| 44 | +</project> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
| 2 | +<project version="4"> | ||
| 3 | + <component name="RunConfigurationProducerService"> | ||
| 4 | + <option name="ignoredProducers"> | ||
| 5 | + <set> | ||
| 6 | + <option value="org.jetbrains.plugins.gradle.execution.test.runner.AllInPackageGradleConfigurationProducer" /> | ||
| 7 | + <option value="org.jetbrains.plugins.gradle.execution.test.runner.TestClassGradleConfigurationProducer" /> | ||
| 8 | + <option value="org.jetbrains.plugins.gradle.execution.test.runner.TestMethodGradleConfigurationProducer" /> | ||
| 9 | + </set> | ||
| 10 | + </option> | ||
| 11 | + </component> | ||
| 12 | +</project> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
Androidstudy_Project/app/.gitignore
0 → 100755
| 1 | +/build |
Androidstudy_Project/app/build.gradle
0 → 100755
| 1 | +apply plugin: 'com.android.application' | ||
| 2 | + | ||
| 3 | +android { | ||
| 4 | + compileSdkVersion 28 | ||
| 5 | + defaultConfig { | ||
| 6 | + applicationId "com.example.androidstudy_project" | ||
| 7 | + minSdkVersion 26 | ||
| 8 | + targetSdkVersion 28 | ||
| 9 | + versionCode 1 | ||
| 10 | + versionName "1.0" | ||
| 11 | + testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" | ||
| 12 | + } | ||
| 13 | + buildTypes { | ||
| 14 | + release { | ||
| 15 | + minifyEnabled false | ||
| 16 | + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' | ||
| 17 | + } | ||
| 18 | + } | ||
| 19 | +} | ||
| 20 | + | ||
| 21 | +dependencies { | ||
| 22 | + implementation fileTree(dir: 'libs', include: ['*.jar']) | ||
| 23 | + implementation 'com.android.support:appcompat-v7:28.0.0' | ||
| 24 | + implementation 'com.android.support:support-media-compat:28.0.0' | ||
| 25 | + implementation 'com.android.support:support-v4:28.0.0' | ||
| 26 | + implementation 'com.android.support.constraint:constraint-layout:1.1.3' | ||
| 27 | + implementation 'com.google.android.gms:play-services-maps:16.1.0' | ||
| 28 | + implementation 'com.google.android.gms:play-services-location:16.0.0' | ||
| 29 | + implementation 'noman.placesapi:placesAPI:1.1.3' | ||
| 30 | + testImplementation 'junit:junit:4.12' | ||
| 31 | + androidTestImplementation 'com.android.support.test:runner:1.0.2' | ||
| 32 | + androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2' | ||
| 33 | +} |
Androidstudy_Project/app/proguard-rules.pro
0 → 100755
| 1 | +# Add project specific ProGuard rules here. | ||
| 2 | +# You can control the set of applied configuration files using the | ||
| 3 | +# proguardFiles setting in build.gradle. | ||
| 4 | +# | ||
| 5 | +# For more details, see | ||
| 6 | +# http://developer.android.com/guide/developing/tools/proguard.html | ||
| 7 | + | ||
| 8 | +# If your project uses WebView with JS, uncomment the following | ||
| 9 | +# and specify the fully qualified class name to the JavaScript interface | ||
| 10 | +# class: | ||
| 11 | +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { | ||
| 12 | +# public *; | ||
| 13 | +#} | ||
| 14 | + | ||
| 15 | +# Uncomment this to preserve the line number information for | ||
| 16 | +# debugging stack traces. | ||
| 17 | +#-keepattributes SourceFile,LineNumberTable | ||
| 18 | + | ||
| 19 | +# If you keep the line number information, uncomment this to | ||
| 20 | +# hide the original source file name. | ||
| 21 | +#-renamesourcefileattribute SourceFile |
| 1 | +package com.example.androidstudy_project; | ||
| 2 | + | ||
| 3 | +import android.content.Context; | ||
| 4 | +import android.support.test.InstrumentationRegistry; | ||
| 5 | +import android.support.test.runner.AndroidJUnit4; | ||
| 6 | + | ||
| 7 | +import org.junit.Test; | ||
| 8 | +import org.junit.runner.RunWith; | ||
| 9 | + | ||
| 10 | +import static org.junit.Assert.*; | ||
| 11 | + | ||
| 12 | +/** | ||
| 13 | + * Instrumented test, which will execute on an Android device. | ||
| 14 | + * | ||
| 15 | + * @see <a href="http://d.android.com/tools/testing">Testing documentation</a> | ||
| 16 | + */ | ||
| 17 | +@RunWith(AndroidJUnit4.class) | ||
| 18 | +public class ExampleInstrumentedTest { | ||
| 19 | + @Test | ||
| 20 | + public void useAppContext() { | ||
| 21 | + // Context of the app under test. | ||
| 22 | + Context appContext = InstrumentationRegistry.getTargetContext(); | ||
| 23 | + | ||
| 24 | + assertEquals("com.example.androidstudy_project", appContext.getPackageName()); | ||
| 25 | + } | ||
| 26 | +} |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<manifest xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + package="com.example.androidstudy_project"> | ||
| 4 | + | ||
| 5 | + <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> | ||
| 6 | + <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/> | ||
| 7 | + <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> | ||
| 8 | + <uses-permission android:name="android.permission.INTERNET" /> | ||
| 9 | + | ||
| 10 | + <application | ||
| 11 | + android:allowBackup="false" | ||
| 12 | + android:icon="@mipmap/ic_launcher" | ||
| 13 | + android:label="@string/app_name" | ||
| 14 | + android:roundIcon="@mipmap/ic_launcher_round" | ||
| 15 | + android:supportsRtl="true" | ||
| 16 | + android:theme="@style/AppTheme"> | ||
| 17 | + | ||
| 18 | + <uses-library android:name="org.apache.http.legacy" android:required="false" /> | ||
| 19 | + | ||
| 20 | + <meta-data | ||
| 21 | + android:name="com.google.android.geo.API_KEY" | ||
| 22 | + android:value="AIzaSyAhweBKf1bsY9C4k9WVAWrjMOV2BAh0qLI" | ||
| 23 | + /> | ||
| 24 | + | ||
| 25 | + <activity android:name=".MainActivity"> | ||
| 26 | + <intent-filter> | ||
| 27 | + <action android:name="android.intent.action.MAIN" /> | ||
| 28 | + | ||
| 29 | + <category android:name="android.intent.category.LAUNCHER" /> | ||
| 30 | + </intent-filter> | ||
| 31 | + </activity> | ||
| 32 | + | ||
| 33 | + <activity android:name=".foodlist"> | ||
| 34 | + | ||
| 35 | + </activity> | ||
| 36 | + | ||
| 37 | + <activity android:name=".foodmenu"> | ||
| 38 | + | ||
| 39 | + </activity> | ||
| 40 | + | ||
| 41 | + <!--<activity android:name=".cafelist">--> | ||
| 42 | + | ||
| 43 | + <!--</activity>--> | ||
| 44 | + | ||
| 45 | + <!--<activity android:name=".cafemenu">--> | ||
| 46 | + | ||
| 47 | + <!--</activity>--> | ||
| 48 | + | ||
| 49 | + <!--<activity android:name=".shoppinglist">--> | ||
| 50 | + | ||
| 51 | + <!--</activity>--> | ||
| 52 | + | ||
| 53 | + <!--<activity android:name=".shoppingmenu">--> | ||
| 54 | + | ||
| 55 | + <!--</activity>--> | ||
| 56 | + | ||
| 57 | + </application> | ||
| 58 | + | ||
| 59 | +</manifest> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
Androidstudy_Project/app/src/main/java/com/example/androidstudy_project/MainActivity.java
0 → 100755
| 1 | + | ||
| 2 | +package com.example.androidstudy_project; | ||
| 3 | + | ||
| 4 | +import android.Manifest; | ||
| 5 | +import android.annotation.TargetApi; | ||
| 6 | +import android.content.DialogInterface; | ||
| 7 | +import android.content.Intent; | ||
| 8 | +import android.content.pm.PackageManager; | ||
| 9 | +import android.location.Address; | ||
| 10 | +import android.location.Geocoder; | ||
| 11 | +import android.location.Location; | ||
| 12 | +import android.location.LocationManager; | ||
| 13 | +import android.net.Uri; | ||
| 14 | +import android.os.Build; | ||
| 15 | +import android.provider.Settings; | ||
| 16 | +import android.support.annotation.NonNull; | ||
| 17 | +import android.support.v4.app.ActivityCompat; | ||
| 18 | +import android.support.v4.content.ContextCompat; | ||
| 19 | +import android.support.v7.app.AlertDialog; | ||
| 20 | +import android.support.v7.app.AppCompatActivity; | ||
| 21 | +import android.os.Bundle; | ||
| 22 | +import android.util.Log; | ||
| 23 | +import android.view.View; | ||
| 24 | +import android.view.WindowManager; | ||
| 25 | +import android.widget.Button; | ||
| 26 | +import android.widget.LinearLayout; | ||
| 27 | +import android.widget.Toast; | ||
| 28 | + | ||
| 29 | +import com.google.android.gms.common.ConnectionResult; | ||
| 30 | +import com.google.android.gms.common.api.GoogleApiClient; | ||
| 31 | +import com.google.android.gms.location.LocationListener; | ||
| 32 | +import com.google.android.gms.location.LocationRequest; | ||
| 33 | +import com.google.android.gms.location.LocationServices; | ||
| 34 | +import com.google.android.gms.maps.CameraUpdate; | ||
| 35 | +import com.google.android.gms.maps.CameraUpdateFactory; | ||
| 36 | +import com.google.android.gms.maps.GoogleMap; | ||
| 37 | +import com.google.android.gms.maps.MapFragment; | ||
| 38 | +import com.google.android.gms.maps.OnMapReadyCallback; | ||
| 39 | +import com.google.android.gms.maps.model.BitmapDescriptorFactory; | ||
| 40 | +import com.google.android.gms.maps.model.LatLng; | ||
| 41 | +import com.google.android.gms.maps.model.Marker; | ||
| 42 | +import com.google.android.gms.maps.model.MarkerOptions; | ||
| 43 | + | ||
| 44 | +import java.io.IOException; | ||
| 45 | +import java.util.ArrayList; | ||
| 46 | +import java.util.HashSet; | ||
| 47 | +import java.util.List; | ||
| 48 | +import java.util.Locale; | ||
| 49 | + | ||
| 50 | +import noman.googleplaces.NRPlaces; | ||
| 51 | +import noman.googleplaces.Place; | ||
| 52 | +import noman.googleplaces.PlaceType; | ||
| 53 | +import noman.googleplaces.PlacesException; | ||
| 54 | +import noman.googleplaces.PlacesListener; | ||
| 55 | + | ||
| 56 | + | ||
| 57 | +public class MainActivity extends AppCompatActivity | ||
| 58 | + implements OnMapReadyCallback, | ||
| 59 | + GoogleApiClient.ConnectionCallbacks, | ||
| 60 | + GoogleApiClient.OnConnectionFailedListener, | ||
| 61 | + LocationListener, | ||
| 62 | + PlacesListener, View.OnClickListener { | ||
| 63 | + | ||
| 64 | + | ||
| 65 | + private GoogleApiClient mGoogleApiClient = null; | ||
| 66 | + private GoogleMap mGoogleMap = null; | ||
| 67 | + private Marker currentMarker = null; | ||
| 68 | + | ||
| 69 | + private static final String TAG = "googlemap_example"; | ||
| 70 | + private static final int GPS_ENABLE_REQUEST_CODE = 2001; | ||
| 71 | + private static final int PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION = 2002; | ||
| 72 | + private static final int UPDATE_INTERVAL_MS = 1000; // 1초 | ||
| 73 | + private static final int FASTEST_UPDATE_INTERVAL_MS = 500; // 0.5초 | ||
| 74 | + | ||
| 75 | + private AppCompatActivity mActivity; | ||
| 76 | + boolean askPermissionOnceAgain = false; | ||
| 77 | + boolean mRequestingLocationUpdates = false; | ||
| 78 | + Location mCurrentLocatiion; | ||
| 79 | + boolean mMoveMapByUser = true; | ||
| 80 | + boolean mMoveMapByAPI = true; | ||
| 81 | + LatLng currentPosition; | ||
| 82 | + | ||
| 83 | + LocationRequest locationRequest = new LocationRequest() | ||
| 84 | + .setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY) | ||
| 85 | + .setInterval(UPDATE_INTERVAL_MS) | ||
| 86 | + .setFastestInterval(FASTEST_UPDATE_INTERVAL_MS); | ||
| 87 | + | ||
| 88 | + List<Marker> previous_marker = null; | ||
| 89 | + String _type; | ||
| 90 | + | ||
| 91 | + @Override | ||
| 92 | + protected void onCreate(Bundle savedInstanceState) { | ||
| 93 | + super.onCreate(savedInstanceState); | ||
| 94 | + | ||
| 95 | + getWindow().setFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON, | ||
| 96 | + WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON); | ||
| 97 | + setContentView(R.layout.activity_main); | ||
| 98 | + | ||
| 99 | + previous_marker = new ArrayList<Marker>(); | ||
| 100 | + | ||
| 101 | + Button Food_button = (Button)findViewById(R.id.Food_button); | ||
| 102 | + Button Foodlist_button = (Button)findViewById(R.id.Foodlist_button); | ||
| 103 | + Button Cafe_button = (Button)findViewById(R.id.Cafe_button); | ||
| 104 | + Button Cafelist_button = (Button)findViewById(R.id.Cafelist_button); | ||
| 105 | + Button Shopping_button = (Button)findViewById(R.id.Shopping_button); | ||
| 106 | + Button Shoppinglist_button = (Button)findViewById(R.id.Shoppinglist_button); | ||
| 107 | + | ||
| 108 | + Food_button.setOnClickListener(this); | ||
| 109 | + Foodlist_button.setOnClickListener(this); | ||
| 110 | + Cafe_button.setOnClickListener(this); | ||
| 111 | + Cafelist_button.setOnClickListener(this); | ||
| 112 | + Shopping_button.setOnClickListener(this); | ||
| 113 | + Shoppinglist_button.setOnClickListener(this); | ||
| 114 | + | ||
| 115 | + | ||
| 116 | + Log.d(TAG, "onCreate"); | ||
| 117 | + mActivity = this; | ||
| 118 | + | ||
| 119 | + | ||
| 120 | + mGoogleApiClient = new GoogleApiClient.Builder(this) | ||
| 121 | + .addConnectionCallbacks(this) | ||
| 122 | + .addOnConnectionFailedListener(this) | ||
| 123 | + .addApi(LocationServices.API) | ||
| 124 | + .build(); | ||
| 125 | + | ||
| 126 | + | ||
| 127 | + MapFragment mapFragment = (MapFragment) getFragmentManager() | ||
| 128 | + .findFragmentById(R.id.map); | ||
| 129 | + mapFragment.getMapAsync(this); | ||
| 130 | + } | ||
| 131 | + | ||
| 132 | + | ||
| 133 | + @Override | ||
| 134 | + public void onResume() { | ||
| 135 | + | ||
| 136 | + super.onResume(); | ||
| 137 | + | ||
| 138 | + if (mGoogleApiClient.isConnected()) { | ||
| 139 | + | ||
| 140 | + Log.d(TAG, "onResume : call startLocationUpdates"); | ||
| 141 | + if (!mRequestingLocationUpdates) startLocationUpdates(); | ||
| 142 | + } | ||
| 143 | + | ||
| 144 | + | ||
| 145 | + //앱 정보에서 퍼미션을 허가했는지를 다시 검사해봐야 한다. | ||
| 146 | + if (askPermissionOnceAgain) { | ||
| 147 | + | ||
| 148 | + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { | ||
| 149 | + askPermissionOnceAgain = false; | ||
| 150 | + | ||
| 151 | + checkPermissions(); | ||
| 152 | + } | ||
| 153 | + } | ||
| 154 | + } | ||
| 155 | + | ||
| 156 | + | ||
| 157 | + private void startLocationUpdates() { | ||
| 158 | + | ||
| 159 | + if (!checkLocationServicesStatus()) { | ||
| 160 | + | ||
| 161 | + Log.d(TAG, "startLocationUpdates : call showDialogForLocationServiceSetting"); | ||
| 162 | + showDialogForLocationServiceSetting(); | ||
| 163 | + }else { | ||
| 164 | + | ||
| 165 | + if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED | ||
| 166 | + && ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) { | ||
| 167 | + | ||
| 168 | + Log.d(TAG, "startLocationUpdates : 퍼미션 안가지고 있음"); | ||
| 169 | + return; | ||
| 170 | + } | ||
| 171 | + | ||
| 172 | + | ||
| 173 | + Log.d(TAG, "startLocationUpdates : call FusedLocationApi.requestLocationUpdates"); | ||
| 174 | + LocationServices.FusedLocationApi.requestLocationUpdates(mGoogleApiClient, locationRequest, this); | ||
| 175 | + mRequestingLocationUpdates = true; | ||
| 176 | + | ||
| 177 | + mGoogleMap.setMyLocationEnabled(true); | ||
| 178 | + | ||
| 179 | + } | ||
| 180 | + | ||
| 181 | + } | ||
| 182 | + | ||
| 183 | + | ||
| 184 | + | ||
| 185 | + private void stopLocationUpdates() { | ||
| 186 | + | ||
| 187 | + Log.d(TAG,"stopLocationUpdates : LocationServices.FusedLocationApi.removeLocationUpdates"); | ||
| 188 | + LocationServices.FusedLocationApi.removeLocationUpdates(mGoogleApiClient, this); | ||
| 189 | + mRequestingLocationUpdates = false; | ||
| 190 | + } | ||
| 191 | + | ||
| 192 | + | ||
| 193 | + | ||
| 194 | + @Override | ||
| 195 | + public void onMapReady(GoogleMap googleMap) { | ||
| 196 | + | ||
| 197 | + Log.d(TAG, "onMapReady :"); | ||
| 198 | + | ||
| 199 | + mGoogleMap = googleMap; | ||
| 200 | + | ||
| 201 | + | ||
| 202 | + //런타임 퍼미션 요청 대화상자나 GPS 활성 요청 대화상자 보이기전에 | ||
| 203 | + //지도의 초기위치를 서울로 이동 | ||
| 204 | + setDefaultLocation(); | ||
| 205 | + | ||
| 206 | + //mGoogleMap.getUiSettings().setZoomControlsEnabled(false); | ||
| 207 | + mGoogleMap.getUiSettings().setMyLocationButtonEnabled(true); | ||
| 208 | + mGoogleMap.animateCamera(CameraUpdateFactory.zoomTo(15)); | ||
| 209 | + mGoogleMap.setOnMyLocationButtonClickListener(new GoogleMap.OnMyLocationButtonClickListener(){ | ||
| 210 | + | ||
| 211 | + @Override | ||
| 212 | + public boolean onMyLocationButtonClick() { | ||
| 213 | + | ||
| 214 | + Log.d( TAG, "onMyLocationButtonClick : 위치에 따른 카메라 이동 활성화"); | ||
| 215 | + mMoveMapByAPI = true; | ||
| 216 | + return true; | ||
| 217 | + } | ||
| 218 | + }); | ||
| 219 | + mGoogleMap.setOnMapClickListener(new GoogleMap.OnMapClickListener() { | ||
| 220 | + | ||
| 221 | + @Override | ||
| 222 | + public void onMapClick(LatLng latLng) { | ||
| 223 | + | ||
| 224 | + Log.d( TAG, "onMapClick :"); | ||
| 225 | + } | ||
| 226 | + }); | ||
| 227 | + | ||
| 228 | + mGoogleMap.setOnCameraMoveStartedListener(new GoogleMap.OnCameraMoveStartedListener() { | ||
| 229 | + | ||
| 230 | + @Override | ||
| 231 | + public void onCameraMoveStarted(int i) { | ||
| 232 | + | ||
| 233 | + if (mMoveMapByUser == true && mRequestingLocationUpdates){ | ||
| 234 | + | ||
| 235 | + Log.d(TAG, "onCameraMove : 위치에 따른 카메라 이동 비활성화"); | ||
| 236 | + mMoveMapByAPI = false; | ||
| 237 | + } | ||
| 238 | + | ||
| 239 | + mMoveMapByUser = true; | ||
| 240 | + | ||
| 241 | + } | ||
| 242 | + }); | ||
| 243 | + | ||
| 244 | + | ||
| 245 | + mGoogleMap.setOnCameraMoveListener(new GoogleMap.OnCameraMoveListener() { | ||
| 246 | + | ||
| 247 | + @Override | ||
| 248 | + public void onCameraMove() { | ||
| 249 | + | ||
| 250 | + | ||
| 251 | + } | ||
| 252 | + }); | ||
| 253 | + | ||
| 254 | + mGoogleMap.setOnInfoWindowClickListener(new GoogleMap.OnInfoWindowClickListener() { | ||
| 255 | + | ||
| 256 | + @Override | ||
| 257 | + public void onInfoWindowClick(Marker marker) { | ||
| 258 | + | ||
| 259 | + Intent intent = new Intent(getBaseContext(), foodlist.class); | ||
| 260 | + | ||
| 261 | + String title = marker.getTitle(); | ||
| 262 | + String address = marker.getSnippet(); | ||
| 263 | + | ||
| 264 | + intent.putExtra("title", title); | ||
| 265 | + intent.putExtra( "address", address); | ||
| 266 | + | ||
| 267 | + startActivity(intent); | ||
| 268 | + } | ||
| 269 | + }); | ||
| 270 | + } | ||
| 271 | + | ||
| 272 | + | ||
| 273 | + @Override | ||
| 274 | + public void onLocationChanged(Location location) { | ||
| 275 | + | ||
| 276 | + currentPosition | ||
| 277 | + = new LatLng( location.getLatitude(), location.getLongitude()); | ||
| 278 | + | ||
| 279 | + | ||
| 280 | + //Log.d(TAG, "onLocationChanged : "); | ||
| 281 | + | ||
| 282 | + String markerTitle = getCurrentAddress(currentPosition); | ||
| 283 | + String markerSnippet = "위도:" + String.valueOf(location.getLatitude()) | ||
| 284 | + + " 경도:" + String.valueOf(location.getLongitude()); | ||
| 285 | + | ||
| 286 | + //현재 위치에 마커 생성하고 이동 | ||
| 287 | + setCurrentLocation(location, markerTitle, markerSnippet); | ||
| 288 | + | ||
| 289 | + mCurrentLocatiion = location; | ||
| 290 | + } | ||
| 291 | + | ||
| 292 | + | ||
| 293 | + @Override | ||
| 294 | + protected void onStart() { | ||
| 295 | + | ||
| 296 | + if(mGoogleApiClient != null && mGoogleApiClient.isConnected() == false){ | ||
| 297 | + | ||
| 298 | + Log.d(TAG, "onStart: mGoogleApiClient connect"); | ||
| 299 | + mGoogleApiClient.connect(); | ||
| 300 | + } | ||
| 301 | + | ||
| 302 | + super.onStart(); | ||
| 303 | + } | ||
| 304 | + | ||
| 305 | + @Override | ||
| 306 | + protected void onStop() { | ||
| 307 | + | ||
| 308 | + if (mRequestingLocationUpdates) { | ||
| 309 | + | ||
| 310 | + Log.d(TAG, "onStop : call stopLocationUpdates"); | ||
| 311 | + stopLocationUpdates(); | ||
| 312 | + } | ||
| 313 | + | ||
| 314 | + if ( mGoogleApiClient.isConnected()) { | ||
| 315 | + | ||
| 316 | + Log.d(TAG, "onStop : mGoogleApiClient disconnect"); | ||
| 317 | + mGoogleApiClient.disconnect(); | ||
| 318 | + } | ||
| 319 | + | ||
| 320 | + super.onStop(); | ||
| 321 | + } | ||
| 322 | + | ||
| 323 | + | ||
| 324 | + @Override | ||
| 325 | + public void onConnected(Bundle connectionHint) { | ||
| 326 | + | ||
| 327 | + | ||
| 328 | + if ( mRequestingLocationUpdates == false ) { | ||
| 329 | + | ||
| 330 | + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { | ||
| 331 | + | ||
| 332 | + int hasFineLocationPermission = ContextCompat.checkSelfPermission(this, | ||
| 333 | + Manifest.permission.ACCESS_FINE_LOCATION); | ||
| 334 | + | ||
| 335 | + if (hasFineLocationPermission == PackageManager.PERMISSION_DENIED) { | ||
| 336 | + | ||
| 337 | + ActivityCompat.requestPermissions(mActivity, | ||
| 338 | + new String[]{android.Manifest.permission.ACCESS_FINE_LOCATION}, | ||
| 339 | + PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION); | ||
| 340 | + | ||
| 341 | + } else { | ||
| 342 | + | ||
| 343 | + Log.d(TAG, "onConnected : 퍼미션 가지고 있음"); | ||
| 344 | + Log.d(TAG, "onConnected : call startLocationUpdates"); | ||
| 345 | + startLocationUpdates(); | ||
| 346 | + mGoogleMap.setMyLocationEnabled(true); | ||
| 347 | + } | ||
| 348 | + | ||
| 349 | + }else{ | ||
| 350 | + | ||
| 351 | + Log.d(TAG, "onConnected : call startLocationUpdates"); | ||
| 352 | + startLocationUpdates(); | ||
| 353 | + mGoogleMap.setMyLocationEnabled(true); | ||
| 354 | + } | ||
| 355 | + } | ||
| 356 | + } | ||
| 357 | + | ||
| 358 | + | ||
| 359 | + @Override | ||
| 360 | + public void onConnectionFailed(ConnectionResult connectionResult) { | ||
| 361 | + | ||
| 362 | + Log.d(TAG, "onConnectionFailed"); | ||
| 363 | + setDefaultLocation(); | ||
| 364 | + } | ||
| 365 | + | ||
| 366 | + | ||
| 367 | + @Override | ||
| 368 | + public void onConnectionSuspended(int cause) { | ||
| 369 | + | ||
| 370 | + Log.d(TAG, "onConnectionSuspended"); | ||
| 371 | + if (cause == CAUSE_NETWORK_LOST) | ||
| 372 | + Log.e(TAG, "onConnectionSuspended(): Google Play services " + | ||
| 373 | + "connection lost. Cause: network lost."); | ||
| 374 | + else if (cause == CAUSE_SERVICE_DISCONNECTED) | ||
| 375 | + Log.e(TAG, "onConnectionSuspended(): Google Play services " + | ||
| 376 | + "connection lost. Cause: service disconnected"); | ||
| 377 | + } | ||
| 378 | + | ||
| 379 | + | ||
| 380 | + public String getCurrentAddress(LatLng latlng) { | ||
| 381 | + | ||
| 382 | + //지오코더... GPS를 주소로 변환 | ||
| 383 | + Geocoder geocoder = new Geocoder(this, Locale.getDefault()); | ||
| 384 | + | ||
| 385 | + List<Address> addresses; | ||
| 386 | + | ||
| 387 | + try { | ||
| 388 | + | ||
| 389 | + addresses = geocoder.getFromLocation( | ||
| 390 | + latlng.latitude, | ||
| 391 | + latlng.longitude, | ||
| 392 | + 1); | ||
| 393 | + } catch (IOException ioException) { | ||
| 394 | + //네트워크 문제 | ||
| 395 | + Toast.makeText(this, "지오코더 서비스 사용불가", Toast.LENGTH_LONG).show(); | ||
| 396 | + return "지오코더 서비스 사용불가"; | ||
| 397 | + } catch (IllegalArgumentException illegalArgumentException) { | ||
| 398 | + Toast.makeText(this, "잘못된 GPS 좌표", Toast.LENGTH_LONG).show(); | ||
| 399 | + return "잘못된 GPS 좌표"; | ||
| 400 | + | ||
| 401 | + } | ||
| 402 | + | ||
| 403 | + | ||
| 404 | + if (addresses == null || addresses.size() == 0) { | ||
| 405 | + Toast.makeText(this, "주소 미발견", Toast.LENGTH_LONG).show(); | ||
| 406 | + return "주소 미발견"; | ||
| 407 | + | ||
| 408 | + } else { | ||
| 409 | + Address address = addresses.get(0); | ||
| 410 | + return address.getAddressLine(0).toString(); | ||
| 411 | + } | ||
| 412 | + | ||
| 413 | + } | ||
| 414 | + | ||
| 415 | + | ||
| 416 | + public boolean checkLocationServicesStatus() { | ||
| 417 | + LocationManager locationManager = (LocationManager) getSystemService(LOCATION_SERVICE); | ||
| 418 | + | ||
| 419 | + return locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER) | ||
| 420 | + || locationManager.isProviderEnabled(LocationManager.NETWORK_PROVIDER); | ||
| 421 | + } | ||
| 422 | + | ||
| 423 | + | ||
| 424 | + public void setCurrentLocation(Location location, String markerTitle, String markerSnippet) { | ||
| 425 | + | ||
| 426 | + mMoveMapByUser = false; | ||
| 427 | + | ||
| 428 | + | ||
| 429 | + if (currentMarker != null) currentMarker.remove(); | ||
| 430 | + | ||
| 431 | + | ||
| 432 | + LatLng currentLatLng = new LatLng(location.getLatitude(), location.getLongitude()); | ||
| 433 | + | ||
| 434 | + MarkerOptions markerOptions = new MarkerOptions(); | ||
| 435 | + markerOptions.position(currentLatLng); | ||
| 436 | + markerOptions.title(markerTitle); | ||
| 437 | + markerOptions.snippet(markerSnippet); | ||
| 438 | + markerOptions.draggable(true); | ||
| 439 | + | ||
| 440 | + | ||
| 441 | + currentMarker = mGoogleMap.addMarker(markerOptions); | ||
| 442 | + | ||
| 443 | + | ||
| 444 | + if ( mMoveMapByAPI ) { | ||
| 445 | + | ||
| 446 | + //Log.d( TAG, "setCurrentLocation : mGoogleMap moveCamera " | ||
| 447 | + // + location.getLatitude() + " " + location.getLongitude() ) ; | ||
| 448 | + // CameraUpdate cameraUpdate = CameraUpdateFactory.newLatLngZoom(currentLatLng, 15); | ||
| 449 | + CameraUpdate cameraUpdate = CameraUpdateFactory.newLatLng(currentLatLng); | ||
| 450 | + mGoogleMap.moveCamera(cameraUpdate); | ||
| 451 | + } | ||
| 452 | + } | ||
| 453 | + | ||
| 454 | + | ||
| 455 | + public void setDefaultLocation() { | ||
| 456 | + | ||
| 457 | + mMoveMapByUser = false; | ||
| 458 | + | ||
| 459 | + | ||
| 460 | + //디폴트 위치, Seoul | ||
| 461 | + LatLng DEFAULT_LOCATION = new LatLng(37.328130, 127.115542); | ||
| 462 | + String markerTitle = "위치정보 가져올 수 없음"; | ||
| 463 | + String markerSnippet = "위치 퍼미션과 GPS 활성 요부 확인하세요"; | ||
| 464 | + | ||
| 465 | + | ||
| 466 | + if (currentMarker != null) currentMarker.remove(); | ||
| 467 | + | ||
| 468 | + MarkerOptions markerOptions = new MarkerOptions(); | ||
| 469 | + markerOptions.position(DEFAULT_LOCATION); | ||
| 470 | + markerOptions.title(markerTitle); | ||
| 471 | + markerOptions.snippet(markerSnippet); | ||
| 472 | + markerOptions.draggable(true); | ||
| 473 | + markerOptions.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_RED)); | ||
| 474 | + currentMarker = mGoogleMap.addMarker(markerOptions); | ||
| 475 | + | ||
| 476 | + CameraUpdate cameraUpdate = CameraUpdateFactory.newLatLngZoom(DEFAULT_LOCATION, 15); | ||
| 477 | + mGoogleMap.moveCamera(cameraUpdate); | ||
| 478 | + | ||
| 479 | + } | ||
| 480 | + | ||
| 481 | + | ||
| 482 | + //여기부터는 런타임 퍼미션 처리을 위한 메소드들 | ||
| 483 | + @TargetApi(Build.VERSION_CODES.M) | ||
| 484 | + private void checkPermissions() { | ||
| 485 | + boolean fineLocationRationale = ActivityCompat | ||
| 486 | + .shouldShowRequestPermissionRationale(this, | ||
| 487 | + Manifest.permission.ACCESS_FINE_LOCATION); | ||
| 488 | + int hasFineLocationPermission = ContextCompat.checkSelfPermission(this, | ||
| 489 | + Manifest.permission.ACCESS_FINE_LOCATION); | ||
| 490 | + | ||
| 491 | + if (hasFineLocationPermission == PackageManager | ||
| 492 | + .PERMISSION_DENIED && fineLocationRationale) | ||
| 493 | + showDialogForPermission("앱을 실행하려면 퍼미션을 허가하셔야합니다."); | ||
| 494 | + | ||
| 495 | + else if (hasFineLocationPermission | ||
| 496 | + == PackageManager.PERMISSION_DENIED && !fineLocationRationale) { | ||
| 497 | + showDialogForPermissionSetting("퍼미션 거부 + Don't ask again(다시 묻지 않음) " + | ||
| 498 | + "체크 박스를 설정한 경우로 설정에서 퍼미션 허가해야합니다."); | ||
| 499 | + } else if (hasFineLocationPermission == PackageManager.PERMISSION_GRANTED) { | ||
| 500 | + | ||
| 501 | + | ||
| 502 | + Log.d(TAG, "checkPermissions : 퍼미션 가지고 있음"); | ||
| 503 | + | ||
| 504 | + if ( mGoogleApiClient.isConnected() == false) { | ||
| 505 | + | ||
| 506 | + Log.d(TAG, "checkPermissions : 퍼미션 가지고 있음"); | ||
| 507 | + mGoogleApiClient.connect(); | ||
| 508 | + } | ||
| 509 | + } | ||
| 510 | + } | ||
| 511 | + | ||
| 512 | + @Override | ||
| 513 | + public void onRequestPermissionsResult(int permsRequestCode, | ||
| 514 | + @NonNull String[] permissions, | ||
| 515 | + @NonNull int[] grantResults) { | ||
| 516 | + | ||
| 517 | + if (permsRequestCode | ||
| 518 | + == PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION && grantResults.length > 0) { | ||
| 519 | + | ||
| 520 | + boolean permissionAccepted = grantResults[0] == PackageManager.PERMISSION_GRANTED; | ||
| 521 | + | ||
| 522 | + if (permissionAccepted) { | ||
| 523 | + | ||
| 524 | + | ||
| 525 | + if ( mGoogleApiClient.isConnected() == false) { | ||
| 526 | + | ||
| 527 | + Log.d(TAG, "onRequestPermissionsResult : mGoogleApiClient connect"); | ||
| 528 | + mGoogleApiClient.connect(); | ||
| 529 | + } | ||
| 530 | + | ||
| 531 | + | ||
| 532 | + | ||
| 533 | + } else { | ||
| 534 | + | ||
| 535 | + checkPermissions(); | ||
| 536 | + } | ||
| 537 | + } | ||
| 538 | + } | ||
| 539 | + | ||
| 540 | + | ||
| 541 | + @TargetApi(Build.VERSION_CODES.M) | ||
| 542 | + private void showDialogForPermission(String msg) { | ||
| 543 | + | ||
| 544 | + AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this); | ||
| 545 | + builder.setTitle("알림"); | ||
| 546 | + builder.setMessage(msg); | ||
| 547 | + builder.setCancelable(false); | ||
| 548 | + builder.setPositiveButton("예", new DialogInterface.OnClickListener() { | ||
| 549 | + public void onClick(DialogInterface dialog, int id) { | ||
| 550 | + ActivityCompat.requestPermissions(mActivity, | ||
| 551 | + new String[]{android.Manifest.permission.ACCESS_FINE_LOCATION}, | ||
| 552 | + PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION); | ||
| 553 | + } | ||
| 554 | + }); | ||
| 555 | + | ||
| 556 | + builder.setNegativeButton("아니오", new DialogInterface.OnClickListener() { | ||
| 557 | + public void onClick(DialogInterface dialog, int id) { | ||
| 558 | + finish(); | ||
| 559 | + } | ||
| 560 | + }); | ||
| 561 | + builder.create().show(); | ||
| 562 | + } | ||
| 563 | + | ||
| 564 | + private void showDialogForPermissionSetting(String msg) { | ||
| 565 | + | ||
| 566 | + AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this); | ||
| 567 | + builder.setTitle("알림"); | ||
| 568 | + builder.setMessage(msg); | ||
| 569 | + builder.setCancelable(true); | ||
| 570 | + builder.setPositiveButton("예", new DialogInterface.OnClickListener() { | ||
| 571 | + public void onClick(DialogInterface dialog, int id) { | ||
| 572 | + | ||
| 573 | + askPermissionOnceAgain = true; | ||
| 574 | + | ||
| 575 | + Intent myAppSettings = new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS, | ||
| 576 | + Uri.parse("package:" + mActivity.getPackageName())); | ||
| 577 | + myAppSettings.addCategory(Intent.CATEGORY_DEFAULT); | ||
| 578 | + myAppSettings.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); | ||
| 579 | + mActivity.startActivity(myAppSettings); | ||
| 580 | + } | ||
| 581 | + }); | ||
| 582 | + builder.setNegativeButton("아니오", new DialogInterface.OnClickListener() { | ||
| 583 | + public void onClick(DialogInterface dialog, int id) { | ||
| 584 | + finish(); | ||
| 585 | + } | ||
| 586 | + }); | ||
| 587 | + builder.create().show(); | ||
| 588 | + } | ||
| 589 | + | ||
| 590 | + | ||
| 591 | + //여기부터는 GPS 활성화를 위한 메소드들 | ||
| 592 | + private void showDialogForLocationServiceSetting() { | ||
| 593 | + | ||
| 594 | + AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this); | ||
| 595 | + builder.setTitle("위치 서비스 비활성화"); | ||
| 596 | + builder.setMessage("앱을 사용하기 위해서는 위치 서비스가 필요합니다.\n" | ||
| 597 | + + "위치 설정을 수정하실래요?"); | ||
| 598 | + builder.setCancelable(true); | ||
| 599 | + builder.setPositiveButton("설정", new DialogInterface.OnClickListener() { | ||
| 600 | + @Override | ||
| 601 | + public void onClick(DialogInterface dialog, int id) { | ||
| 602 | + Intent callGPSSettingIntent | ||
| 603 | + = new Intent(android.provider.Settings.ACTION_LOCATION_SOURCE_SETTINGS); | ||
| 604 | + startActivityForResult(callGPSSettingIntent, GPS_ENABLE_REQUEST_CODE); | ||
| 605 | + } | ||
| 606 | + }); | ||
| 607 | + builder.setNegativeButton("취소", new DialogInterface.OnClickListener() { | ||
| 608 | + @Override | ||
| 609 | + public void onClick(DialogInterface dialog, int id) { | ||
| 610 | + dialog.cancel(); | ||
| 611 | + } | ||
| 612 | + }); | ||
| 613 | + builder.create().show(); | ||
| 614 | + } | ||
| 615 | + | ||
| 616 | + | ||
| 617 | + @Override | ||
| 618 | + protected void onActivityResult(int requestCode, int resultCode, Intent data) { | ||
| 619 | + super.onActivityResult(requestCode, resultCode, data); | ||
| 620 | + | ||
| 621 | + switch (requestCode) { | ||
| 622 | + | ||
| 623 | + case GPS_ENABLE_REQUEST_CODE: | ||
| 624 | + | ||
| 625 | + //사용자가 GPS 활성 시켰는지 검사 | ||
| 626 | + if (checkLocationServicesStatus()) { | ||
| 627 | + if (checkLocationServicesStatus()) { | ||
| 628 | + | ||
| 629 | + Log.d(TAG, "onActivityResult : 퍼미션 가지고 있음"); | ||
| 630 | + | ||
| 631 | + | ||
| 632 | + if ( mGoogleApiClient.isConnected() == false ) { | ||
| 633 | + | ||
| 634 | + Log.d( TAG, "onActivityResult : mGoogleApiClient connect "); | ||
| 635 | + mGoogleApiClient.connect(); | ||
| 636 | + } | ||
| 637 | + return; | ||
| 638 | + } | ||
| 639 | + } | ||
| 640 | + | ||
| 641 | + break; | ||
| 642 | + } | ||
| 643 | + } | ||
| 644 | + | ||
| 645 | + | ||
| 646 | + @Override | ||
| 647 | + public void onPlacesFailure(PlacesException e) { | ||
| 648 | + | ||
| 649 | + } | ||
| 650 | + | ||
| 651 | + @Override | ||
| 652 | + public void onPlacesStart() { | ||
| 653 | + | ||
| 654 | + } | ||
| 655 | + | ||
| 656 | + @Override | ||
| 657 | + public void onPlacesSuccess(final List<Place> places) { | ||
| 658 | + | ||
| 659 | + runOnUiThread(new Runnable() { | ||
| 660 | + | ||
| 661 | + @Override | ||
| 662 | + | ||
| 663 | + public void run() { | ||
| 664 | + | ||
| 665 | + for (noman.googleplaces.Place place : places) { | ||
| 666 | + | ||
| 667 | + | ||
| 668 | + LatLng latLng | ||
| 669 | + | ||
| 670 | + = new LatLng(place.getLatitude() | ||
| 671 | + | ||
| 672 | + , place.getLongitude()); | ||
| 673 | + | ||
| 674 | + | ||
| 675 | + String markerSnippet = getCurrentAddress(latLng); | ||
| 676 | + | ||
| 677 | + | ||
| 678 | + MarkerOptions markerOptions = new MarkerOptions(); | ||
| 679 | + | ||
| 680 | + markerOptions.position(latLng); | ||
| 681 | + | ||
| 682 | + markerOptions.title(place.getName()); | ||
| 683 | + | ||
| 684 | + markerOptions.snippet(markerSnippet); | ||
| 685 | + | ||
| 686 | + Marker item = mGoogleMap.addMarker(markerOptions); | ||
| 687 | + | ||
| 688 | + previous_marker.add(item); | ||
| 689 | + | ||
| 690 | + | ||
| 691 | + } | ||
| 692 | + | ||
| 693 | + | ||
| 694 | + //중복 마커 제거 | ||
| 695 | + | ||
| 696 | + HashSet<Marker> hashSet = new HashSet<Marker>(); | ||
| 697 | + | ||
| 698 | + hashSet.addAll(previous_marker); | ||
| 699 | + | ||
| 700 | + previous_marker.clear(); | ||
| 701 | + | ||
| 702 | + previous_marker.addAll(hashSet); | ||
| 703 | + | ||
| 704 | + | ||
| 705 | + } | ||
| 706 | + | ||
| 707 | + }); | ||
| 708 | + } | ||
| 709 | + | ||
| 710 | + @Override | ||
| 711 | + public void onPlacesFinished() { | ||
| 712 | + | ||
| 713 | + } | ||
| 714 | + | ||
| 715 | + public void showPlaceInformation(LatLng location,String _type) | ||
| 716 | + { | ||
| 717 | + mGoogleMap.clear();//지도 클리어 | ||
| 718 | + | ||
| 719 | + if (previous_marker != null) | ||
| 720 | + previous_marker.clear();//지역정보 마커 클리어 | ||
| 721 | + | ||
| 722 | + if(_type.equals("RESTAURANT")) { | ||
| 723 | + new NRPlaces.Builder() | ||
| 724 | + .listener(MainActivity.this) | ||
| 725 | + .key("AIzaSyDLrbLwej4b0LlGL1cTPH9HHuzl-fot9yo") | ||
| 726 | + .latlng(location.latitude, location.longitude)//현재 위치 | ||
| 727 | + .radius(500) //500 미터 내에서 검색 | ||
| 728 | + .type(PlaceType.RESTAURANT) //음식점 | ||
| 729 | + //.type(PlaceType.CAFE) //카페 | ||
| 730 | + .build() | ||
| 731 | + .execute(); | ||
| 732 | + Log.d("TAG","---print---"); | ||
| 733 | + Log.d("TAG",previous_marker.toString()); | ||
| 734 | + Log.d("TAG","---print---"); | ||
| 735 | + } | ||
| 736 | + else if(_type.equals("CAFE")) { | ||
| 737 | + new NRPlaces.Builder() | ||
| 738 | + .listener(MainActivity.this) | ||
| 739 | + .key("AIzaSyDLrbLwej4b0LlGL1cTPH9HHuzl-fot9yo") | ||
| 740 | + .latlng(location.latitude, location.longitude)//현재 위치 | ||
| 741 | + .radius(500) //500 미터 내에서 검색 | ||
| 742 | + .type(PlaceType.CAFE) //카페 | ||
| 743 | + .build() | ||
| 744 | + .execute(); | ||
| 745 | + } | ||
| 746 | + else if(_type.equals("SHOPPING_MALL")) { | ||
| 747 | + new NRPlaces.Builder() | ||
| 748 | + .listener(MainActivity.this) | ||
| 749 | + .key("AIzaSyDLrbLwej4b0LlGL1cTPH9HHuzl-fot9yo") | ||
| 750 | + .latlng(location.latitude, location.longitude)//현재 위치 | ||
| 751 | + .radius(500) //500 미터 내에서 검색 | ||
| 752 | + .type(PlaceType.SHOPPING_MALL) //쇼핑물 | ||
| 753 | + .build() | ||
| 754 | + .execute(); | ||
| 755 | + } | ||
| 756 | + } | ||
| 757 | + | ||
| 758 | + public void PrintPlacelist(String _type) | ||
| 759 | + { | ||
| 760 | + Log.d("TAG","000000000000000"); | ||
| 761 | + Log.d("TAG",previous_marker.get(0).toString()); | ||
| 762 | + Log.d("TAG",previous_marker.get(0).getTitle().toString()); | ||
| 763 | + Log.d("TAG",previous_marker.get(0).getSnippet().toString()); | ||
| 764 | + int length = previous_marker.size(); | ||
| 765 | + String numstr2 = String.valueOf(length); | ||
| 766 | + Log.d("TAG",numstr2); | ||
| 767 | + | ||
| 768 | + | ||
| 769 | +// for(int i=0;i<length;i++) | ||
| 770 | +// { | ||
| 771 | +//// foodmenu n_layout = new foodmenu(getApplicationContext()); | ||
| 772 | +//// LinearLayout con = (LinearLayout)findViewById(R.id.con); | ||
| 773 | +//// con.addView(n_layout); | ||
| 774 | +// Intent intent = new Intent(getBaseContext(), foodmenu.class); | ||
| 775 | +// | ||
| 776 | +// String title = previous_marker.get(i).getTitle().toString(); | ||
| 777 | +// String address = previous_marker.get(i).getSnippet().toString(); | ||
| 778 | +// | ||
| 779 | +// Log.d("TAG",previous_marker.get(i).getTitle().toString()); | ||
| 780 | +// Log.d("TAG",previous_marker.get(i).getSnippet().toString()); | ||
| 781 | +// intent.putExtra("title", title); | ||
| 782 | +// intent.putExtra( "address", address); | ||
| 783 | +// | ||
| 784 | +// | ||
| 785 | +// startActivity(intent); | ||
| 786 | +// } | ||
| 787 | + | ||
| 788 | + for(int i=0;i<length;i++) | ||
| 789 | + { | ||
| 790 | +// foodmenu n_layout = new foodmenu(getApplicationContext()); | ||
| 791 | +// LinearLayout con = (LinearLayout)findViewById(R.id.con); | ||
| 792 | +// con.addView(n_layout); | ||
| 793 | + | ||
| 794 | + Log.d("TAG",previous_marker.get(i).getTitle().toString()); | ||
| 795 | + Log.d("TAG",previous_marker.get(i).getSnippet().toString()); | ||
| 796 | + } | ||
| 797 | + | ||
| 798 | + Intent intent = new Intent(getBaseContext(), foodmenu.class); | ||
| 799 | + | ||
| 800 | + String title = previous_marker.get(0).getTitle().toString(); | ||
| 801 | + String address = previous_marker.get(0).getSnippet().toString(); | ||
| 802 | + | ||
| 803 | + intent.putExtra("title", title); | ||
| 804 | + intent.putExtra( "address", address); | ||
| 805 | + | ||
| 806 | + | ||
| 807 | + startActivity(intent); | ||
| 808 | + } | ||
| 809 | + | ||
| 810 | + @Override | ||
| 811 | + public void onClick(View v) { | ||
| 812 | + switch(v.getId()) | ||
| 813 | + { | ||
| 814 | + case R.id.Food_button: | ||
| 815 | + _type = "RESTAURANT"; | ||
| 816 | + Log.d(TAG, "click food_button"); | ||
| 817 | + showPlaceInformation(currentPosition,_type); | ||
| 818 | + break; | ||
| 819 | + case R.id.Foodlist_button: | ||
| 820 | + _type = "RESTAURANT"; | ||
| 821 | + Log.d(TAG, "click foodlist_button"); | ||
| 822 | + PrintPlacelist(_type); | ||
| 823 | + //showPlaceInformation(currentPosition,_type); | ||
| 824 | + break; | ||
| 825 | + case R.id.Cafe_button: | ||
| 826 | + _type = "CAFE"; | ||
| 827 | + Log.d(TAG, "click cafe_button"); | ||
| 828 | + showPlaceInformation(currentPosition,_type); | ||
| 829 | + break; | ||
| 830 | + case R.id.Cafelist_button: | ||
| 831 | + _type = "CAFE"; | ||
| 832 | + Log.d(TAG, "click cafelist_button"); | ||
| 833 | + PrintPlacelist(_type); | ||
| 834 | + break; | ||
| 835 | + case R.id.Shopping_button: | ||
| 836 | + _type = "SHOPPING_MALL"; | ||
| 837 | + Log.d(TAG, "click shopping_button"); | ||
| 838 | + showPlaceInformation(currentPosition,_type); | ||
| 839 | + break; | ||
| 840 | + case R.id.Shoppinglist_button: | ||
| 841 | + _type = "SHOPPING_MALL"; | ||
| 842 | + Log.d(TAG, "click shoopinglist_button"); | ||
| 843 | + PrintPlacelist(_type); | ||
| 844 | + break; | ||
| 845 | + } | ||
| 846 | + } | ||
| 847 | +} | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +package com.example.androidstudy_project; | ||
| 2 | + | ||
| 3 | +import android.content.Context; | ||
| 4 | +import android.util.AttributeSet; | ||
| 5 | +import android.view.LayoutInflater; | ||
| 6 | +import android.widget.LinearLayout; | ||
| 7 | + | ||
| 8 | +public class Sub extends LinearLayout { | ||
| 9 | + public Sub(Context context, AttributeSet attrs) { | ||
| 10 | + super(context, attrs); | ||
| 11 | + | ||
| 12 | + init(context); | ||
| 13 | + } | ||
| 14 | + | ||
| 15 | + public Sub(Context context) { | ||
| 16 | + super(context); | ||
| 17 | + | ||
| 18 | + init(context); | ||
| 19 | + } | ||
| 20 | + private void init(Context context){ | ||
| 21 | + LayoutInflater inflater =(LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); | ||
| 22 | + inflater.inflate(R.layout.foodmenu,this,true); | ||
| 23 | + } | ||
| 24 | +} |
| 1 | +package com.example.androidstudy_project; | ||
| 2 | + | ||
| 3 | +import android.os.Bundle; | ||
| 4 | +import android.support.annotation.Nullable; | ||
| 5 | +import android.support.v7.app.AppCompatActivity; | ||
| 6 | +import android.widget.TextView; | ||
| 7 | + | ||
| 8 | +import com.google.android.gms.maps.model.Marker; | ||
| 9 | + | ||
| 10 | +import java.util.ArrayList; | ||
| 11 | +import java.util.List; | ||
| 12 | + | ||
| 13 | +public class foodlist extends AppCompatActivity | ||
| 14 | +{ | ||
| 15 | + List<Marker> previous_marker = null; | ||
| 16 | + | ||
| 17 | + @Override | ||
| 18 | + public void onCreate(Bundle savedInstanceState) { | ||
| 19 | + super.onCreate(savedInstanceState); | ||
| 20 | + setContentView(R.layout.foodlist); | ||
| 21 | + previous_marker = new ArrayList<Marker>(); | ||
| 22 | + | ||
| 23 | + String title = " "; | ||
| 24 | + String address = " "; | ||
| 25 | + | ||
| 26 | + Bundle extras = getIntent().getExtras(); | ||
| 27 | + | ||
| 28 | + if(extras == null) | ||
| 29 | + { | ||
| 30 | + title = "error"; | ||
| 31 | + } | ||
| 32 | + else | ||
| 33 | + { | ||
| 34 | + title = extras.getString("title"); | ||
| 35 | + address = extras.getString("address"); | ||
| 36 | + } | ||
| 37 | + | ||
| 38 | + TextView textView = (TextView) findViewById(R.id._foodlist); | ||
| 39 | + | ||
| 40 | + String str = title + '\n' + address + '\n'; | ||
| 41 | + textView.setText(str); | ||
| 42 | + } | ||
| 43 | +} |
| 1 | +package com.example.androidstudy_project; | ||
| 2 | + | ||
| 3 | +import android.content.Context; | ||
| 4 | +import android.content.Intent; | ||
| 5 | +import android.os.Bundle; | ||
| 6 | +import android.util.AttributeSet; | ||
| 7 | +import android.view.LayoutInflater; | ||
| 8 | +import android.view.View; | ||
| 9 | +import android.widget.Button; | ||
| 10 | +import android.widget.TextView; | ||
| 11 | + | ||
| 12 | +public class foodmenu extends MainActivity { | ||
| 13 | + | ||
| 14 | + private TextView name; | ||
| 15 | + private TextView address; | ||
| 16 | + private Button btnBack; | ||
| 17 | + | ||
| 18 | + String _name; | ||
| 19 | + String _address; | ||
| 20 | + | ||
| 21 | + private static final String TAG = "foodmenu"; | ||
| 22 | + | ||
| 23 | +// public foodmenu(Context context, AttributeSet attrs) { | ||
| 24 | +// super(context, attrs); | ||
| 25 | +// | ||
| 26 | +// init(context); | ||
| 27 | +// } | ||
| 28 | +// | ||
| 29 | +// public foodmenu(Context context) { | ||
| 30 | +// super(context); | ||
| 31 | +// | ||
| 32 | +// init(context); | ||
| 33 | +// } | ||
| 34 | +// private void init(Context context){ | ||
| 35 | +// LayoutInflater inflater =(LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); | ||
| 36 | +// //inflater.inflate(R.layout.foodmenu,this,true); | ||
| 37 | +// } | ||
| 38 | + | ||
| 39 | + @Override | ||
| 40 | + protected void onCreate(Bundle savedInstanceState) { | ||
| 41 | + super.onCreate(savedInstanceState); | ||
| 42 | + setContentView(R.layout.foodmenu); | ||
| 43 | + | ||
| 44 | + name = (TextView) findViewById(R.id._name); | ||
| 45 | + address = (TextView) findViewById(R.id._address); | ||
| 46 | + btnBack = (Button) findViewById(R.id.btnBack); | ||
| 47 | + btnBack.setOnClickListener(this); | ||
| 48 | + | ||
| 49 | + Bundle extras = getIntent().getExtras(); | ||
| 50 | + | ||
| 51 | + if(extras == null) | ||
| 52 | + { | ||
| 53 | + _name = "error"; | ||
| 54 | + } | ||
| 55 | + else | ||
| 56 | + { | ||
| 57 | + _name = extras.getString("title"); | ||
| 58 | + _address = extras.getString("address"); | ||
| 59 | + } | ||
| 60 | + | ||
| 61 | + name.setText(_name); | ||
| 62 | + address.setText(_address); | ||
| 63 | + } | ||
| 64 | + | ||
| 65 | + @Override | ||
| 66 | + public void onClick(View v) { | ||
| 67 | + switch (v.getId()) | ||
| 68 | + { | ||
| 69 | + case R.id.btnBack: | ||
| 70 | + finish(); | ||
| 71 | + } | ||
| 72 | + } | ||
| 73 | +} |
| 1 | +<vector xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 2 | + xmlns:aapt="http://schemas.android.com/aapt" | ||
| 3 | + android:width="108dp" | ||
| 4 | + android:height="108dp" | ||
| 5 | + android:viewportWidth="108" | ||
| 6 | + android:viewportHeight="108"> | ||
| 7 | + <path | ||
| 8 | + android:fillType="evenOdd" | ||
| 9 | + android:pathData="M32,64C32,64 38.39,52.99 44.13,50.95C51.37,48.37 70.14,49.57 70.14,49.57L108.26,87.69L108,109.01L75.97,107.97L32,64Z" | ||
| 10 | + android:strokeWidth="1" | ||
| 11 | + android:strokeColor="#00000000"> | ||
| 12 | + <aapt:attr name="android:fillColor"> | ||
| 13 | + <gradient | ||
| 14 | + android:endX="78.5885" | ||
| 15 | + android:endY="90.9159" | ||
| 16 | + android:startX="48.7653" | ||
| 17 | + android:startY="61.0927" | ||
| 18 | + android:type="linear"> | ||
| 19 | + <item | ||
| 20 | + android:color="#44000000" | ||
| 21 | + android:offset="0.0" /> | ||
| 22 | + <item | ||
| 23 | + android:color="#00000000" | ||
| 24 | + android:offset="1.0" /> | ||
| 25 | + </gradient> | ||
| 26 | + </aapt:attr> | ||
| 27 | + </path> | ||
| 28 | + <path | ||
| 29 | + android:fillColor="#FFFFFF" | ||
| 30 | + android:fillType="nonZero" | ||
| 31 | + android:pathData="M66.94,46.02L66.94,46.02C72.44,50.07 76,56.61 76,64L32,64C32,56.61 35.56,50.11 40.98,46.06L36.18,41.19C35.45,40.45 35.45,39.3 36.18,38.56C36.91,37.81 38.05,37.81 38.78,38.56L44.25,44.05C47.18,42.57 50.48,41.71 54,41.71C57.48,41.71 60.78,42.57 63.68,44.05L69.11,38.56C69.84,37.81 70.98,37.81 71.71,38.56C72.44,39.3 72.44,40.45 71.71,41.19L66.94,46.02ZM62.94,56.92C64.08,56.92 65,56.01 65,54.88C65,53.76 64.08,52.85 62.94,52.85C61.8,52.85 60.88,53.76 60.88,54.88C60.88,56.01 61.8,56.92 62.94,56.92ZM45.06,56.92C46.2,56.92 47.13,56.01 47.13,54.88C47.13,53.76 46.2,52.85 45.06,52.85C43.92,52.85 43,53.76 43,54.88C43,56.01 43.92,56.92 45.06,56.92Z" | ||
| 32 | + android:strokeWidth="1" | ||
| 33 | + android:strokeColor="#00000000" /> | ||
| 34 | +</vector> |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<vector xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + android:width="108dp" | ||
| 4 | + android:height="108dp" | ||
| 5 | + android:viewportWidth="108" | ||
| 6 | + android:viewportHeight="108"> | ||
| 7 | + <path | ||
| 8 | + android:fillColor="#008577" | ||
| 9 | + android:pathData="M0,0h108v108h-108z" /> | ||
| 10 | + <path | ||
| 11 | + android:fillColor="#00000000" | ||
| 12 | + android:pathData="M9,0L9,108" | ||
| 13 | + android:strokeWidth="0.8" | ||
| 14 | + android:strokeColor="#33FFFFFF" /> | ||
| 15 | + <path | ||
| 16 | + android:fillColor="#00000000" | ||
| 17 | + android:pathData="M19,0L19,108" | ||
| 18 | + android:strokeWidth="0.8" | ||
| 19 | + android:strokeColor="#33FFFFFF" /> | ||
| 20 | + <path | ||
| 21 | + android:fillColor="#00000000" | ||
| 22 | + android:pathData="M29,0L29,108" | ||
| 23 | + android:strokeWidth="0.8" | ||
| 24 | + android:strokeColor="#33FFFFFF" /> | ||
| 25 | + <path | ||
| 26 | + android:fillColor="#00000000" | ||
| 27 | + android:pathData="M39,0L39,108" | ||
| 28 | + android:strokeWidth="0.8" | ||
| 29 | + android:strokeColor="#33FFFFFF" /> | ||
| 30 | + <path | ||
| 31 | + android:fillColor="#00000000" | ||
| 32 | + android:pathData="M49,0L49,108" | ||
| 33 | + android:strokeWidth="0.8" | ||
| 34 | + android:strokeColor="#33FFFFFF" /> | ||
| 35 | + <path | ||
| 36 | + android:fillColor="#00000000" | ||
| 37 | + android:pathData="M59,0L59,108" | ||
| 38 | + android:strokeWidth="0.8" | ||
| 39 | + android:strokeColor="#33FFFFFF" /> | ||
| 40 | + <path | ||
| 41 | + android:fillColor="#00000000" | ||
| 42 | + android:pathData="M69,0L69,108" | ||
| 43 | + android:strokeWidth="0.8" | ||
| 44 | + android:strokeColor="#33FFFFFF" /> | ||
| 45 | + <path | ||
| 46 | + android:fillColor="#00000000" | ||
| 47 | + android:pathData="M79,0L79,108" | ||
| 48 | + android:strokeWidth="0.8" | ||
| 49 | + android:strokeColor="#33FFFFFF" /> | ||
| 50 | + <path | ||
| 51 | + android:fillColor="#00000000" | ||
| 52 | + android:pathData="M89,0L89,108" | ||
| 53 | + android:strokeWidth="0.8" | ||
| 54 | + android:strokeColor="#33FFFFFF" /> | ||
| 55 | + <path | ||
| 56 | + android:fillColor="#00000000" | ||
| 57 | + android:pathData="M99,0L99,108" | ||
| 58 | + android:strokeWidth="0.8" | ||
| 59 | + android:strokeColor="#33FFFFFF" /> | ||
| 60 | + <path | ||
| 61 | + android:fillColor="#00000000" | ||
| 62 | + android:pathData="M0,9L108,9" | ||
| 63 | + android:strokeWidth="0.8" | ||
| 64 | + android:strokeColor="#33FFFFFF" /> | ||
| 65 | + <path | ||
| 66 | + android:fillColor="#00000000" | ||
| 67 | + android:pathData="M0,19L108,19" | ||
| 68 | + android:strokeWidth="0.8" | ||
| 69 | + android:strokeColor="#33FFFFFF" /> | ||
| 70 | + <path | ||
| 71 | + android:fillColor="#00000000" | ||
| 72 | + android:pathData="M0,29L108,29" | ||
| 73 | + android:strokeWidth="0.8" | ||
| 74 | + android:strokeColor="#33FFFFFF" /> | ||
| 75 | + <path | ||
| 76 | + android:fillColor="#00000000" | ||
| 77 | + android:pathData="M0,39L108,39" | ||
| 78 | + android:strokeWidth="0.8" | ||
| 79 | + android:strokeColor="#33FFFFFF" /> | ||
| 80 | + <path | ||
| 81 | + android:fillColor="#00000000" | ||
| 82 | + android:pathData="M0,49L108,49" | ||
| 83 | + android:strokeWidth="0.8" | ||
| 84 | + android:strokeColor="#33FFFFFF" /> | ||
| 85 | + <path | ||
| 86 | + android:fillColor="#00000000" | ||
| 87 | + android:pathData="M0,59L108,59" | ||
| 88 | + android:strokeWidth="0.8" | ||
| 89 | + android:strokeColor="#33FFFFFF" /> | ||
| 90 | + <path | ||
| 91 | + android:fillColor="#00000000" | ||
| 92 | + android:pathData="M0,69L108,69" | ||
| 93 | + android:strokeWidth="0.8" | ||
| 94 | + android:strokeColor="#33FFFFFF" /> | ||
| 95 | + <path | ||
| 96 | + android:fillColor="#00000000" | ||
| 97 | + android:pathData="M0,79L108,79" | ||
| 98 | + android:strokeWidth="0.8" | ||
| 99 | + android:strokeColor="#33FFFFFF" /> | ||
| 100 | + <path | ||
| 101 | + android:fillColor="#00000000" | ||
| 102 | + android:pathData="M0,89L108,89" | ||
| 103 | + android:strokeWidth="0.8" | ||
| 104 | + android:strokeColor="#33FFFFFF" /> | ||
| 105 | + <path | ||
| 106 | + android:fillColor="#00000000" | ||
| 107 | + android:pathData="M0,99L108,99" | ||
| 108 | + android:strokeWidth="0.8" | ||
| 109 | + android:strokeColor="#33FFFFFF" /> | ||
| 110 | + <path | ||
| 111 | + android:fillColor="#00000000" | ||
| 112 | + android:pathData="M19,29L89,29" | ||
| 113 | + android:strokeWidth="0.8" | ||
| 114 | + android:strokeColor="#33FFFFFF" /> | ||
| 115 | + <path | ||
| 116 | + android:fillColor="#00000000" | ||
| 117 | + android:pathData="M19,39L89,39" | ||
| 118 | + android:strokeWidth="0.8" | ||
| 119 | + android:strokeColor="#33FFFFFF" /> | ||
| 120 | + <path | ||
| 121 | + android:fillColor="#00000000" | ||
| 122 | + android:pathData="M19,49L89,49" | ||
| 123 | + android:strokeWidth="0.8" | ||
| 124 | + android:strokeColor="#33FFFFFF" /> | ||
| 125 | + <path | ||
| 126 | + android:fillColor="#00000000" | ||
| 127 | + android:pathData="M19,59L89,59" | ||
| 128 | + android:strokeWidth="0.8" | ||
| 129 | + android:strokeColor="#33FFFFFF" /> | ||
| 130 | + <path | ||
| 131 | + android:fillColor="#00000000" | ||
| 132 | + android:pathData="M19,69L89,69" | ||
| 133 | + android:strokeWidth="0.8" | ||
| 134 | + android:strokeColor="#33FFFFFF" /> | ||
| 135 | + <path | ||
| 136 | + android:fillColor="#00000000" | ||
| 137 | + android:pathData="M19,79L89,79" | ||
| 138 | + android:strokeWidth="0.8" | ||
| 139 | + android:strokeColor="#33FFFFFF" /> | ||
| 140 | + <path | ||
| 141 | + android:fillColor="#00000000" | ||
| 142 | + android:pathData="M29,19L29,89" | ||
| 143 | + android:strokeWidth="0.8" | ||
| 144 | + android:strokeColor="#33FFFFFF" /> | ||
| 145 | + <path | ||
| 146 | + android:fillColor="#00000000" | ||
| 147 | + android:pathData="M39,19L39,89" | ||
| 148 | + android:strokeWidth="0.8" | ||
| 149 | + android:strokeColor="#33FFFFFF" /> | ||
| 150 | + <path | ||
| 151 | + android:fillColor="#00000000" | ||
| 152 | + android:pathData="M49,19L49,89" | ||
| 153 | + android:strokeWidth="0.8" | ||
| 154 | + android:strokeColor="#33FFFFFF" /> | ||
| 155 | + <path | ||
| 156 | + android:fillColor="#00000000" | ||
| 157 | + android:pathData="M59,19L59,89" | ||
| 158 | + android:strokeWidth="0.8" | ||
| 159 | + android:strokeColor="#33FFFFFF" /> | ||
| 160 | + <path | ||
| 161 | + android:fillColor="#00000000" | ||
| 162 | + android:pathData="M69,19L69,89" | ||
| 163 | + android:strokeWidth="0.8" | ||
| 164 | + android:strokeColor="#33FFFFFF" /> | ||
| 165 | + <path | ||
| 166 | + android:fillColor="#00000000" | ||
| 167 | + android:pathData="M79,19L79,89" | ||
| 168 | + android:strokeWidth="0.8" | ||
| 169 | + android:strokeColor="#33FFFFFF" /> | ||
| 170 | +</vector> |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<GridLayout | ||
| 3 | + xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 4 | + xmlns:tools="http://schemas.android.com/tools" | ||
| 5 | + xmlns:app="http://schemas.android.com/apk/res-auto" | ||
| 6 | + android:layout_width="match_parent" | ||
| 7 | + android:layout_height="match_parent" | ||
| 8 | + android:orientation="vertical" | ||
| 9 | + tools:context=".MainActivity"> | ||
| 10 | + | ||
| 11 | + <fragment xmlns:map="http://schemas.android.com/apk/res-auto" | ||
| 12 | + android:id="@+id/map" | ||
| 13 | + android:layout_width="match_parent" | ||
| 14 | + android:layout_height="400dp" | ||
| 15 | + class="com.google.android.gms.maps.MapFragment" | ||
| 16 | + | ||
| 17 | + /> | ||
| 18 | + | ||
| 19 | + <TableLayout> | ||
| 20 | + | ||
| 21 | + <TableRow> | ||
| 22 | + <Button | ||
| 23 | + android:text="FOOD" | ||
| 24 | + android:layout_width="150dp" | ||
| 25 | + android:layout_height="35dp" | ||
| 26 | + android:id="@+id/Food_button" | ||
| 27 | + tools:ignore="HardcodedText" /> | ||
| 28 | + | ||
| 29 | + <Button | ||
| 30 | + android:text="FOOD_LIST" | ||
| 31 | + android:layout_width="150dp" | ||
| 32 | + android:layout_height="35dp" | ||
| 33 | + android:id="@+id/Foodlist_button" | ||
| 34 | + tools:ignore="HardcodedText" /> | ||
| 35 | + </TableRow> | ||
| 36 | + | ||
| 37 | + <TableRow> | ||
| 38 | + <Button | ||
| 39 | + android:text="CAFE" | ||
| 40 | + android:layout_width="150dp" | ||
| 41 | + android:layout_height="35dp" | ||
| 42 | + android:id="@+id/Cafe_button" | ||
| 43 | + tools:ignore="HardcodedText" /> | ||
| 44 | + | ||
| 45 | + <Button | ||
| 46 | + android:text="CAFE_LIST" | ||
| 47 | + android:layout_width="150dp" | ||
| 48 | + android:layout_height="35dp" | ||
| 49 | + android:id="@+id/Cafelist_button" | ||
| 50 | + tools:ignore="HardcodedText" /> | ||
| 51 | + </TableRow> | ||
| 52 | + | ||
| 53 | + <TableRow> | ||
| 54 | + <Button | ||
| 55 | + android:text="SHOPPING_MALL" | ||
| 56 | + android:layout_width="150dp" | ||
| 57 | + android:layout_height="35dp" | ||
| 58 | + android:id="@+id/Shopping_button" | ||
| 59 | + tools:ignore="HardcodedText" /> | ||
| 60 | + | ||
| 61 | + <Button | ||
| 62 | + android:text="SHOPPING_MALL_LIST" | ||
| 63 | + android:layout_width="150dp" | ||
| 64 | + android:layout_height="35dp" | ||
| 65 | + android:id="@+id/Shoppinglist_button" | ||
| 66 | + tools:ignore="HardcodedText" /> | ||
| 67 | + </TableRow> | ||
| 68 | + </TableLayout> | ||
| 69 | + | ||
| 70 | + <LinearLayout | ||
| 71 | + android:id="@+id/con" | ||
| 72 | + android:orientation="vertical" | ||
| 73 | + android:layout_width="match_parent" | ||
| 74 | + android:layout_height="match_parent" | ||
| 75 | + android:layout_below="@+id/add_layout" | ||
| 76 | + android:layout_alignParentLeft="true" | ||
| 77 | + android:layout_alignParentStart="true"> | ||
| 78 | + </LinearLayout> | ||
| 79 | + | ||
| 80 | + | ||
| 81 | +</GridLayout> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + android:orientation="vertical" android:layout_width="match_parent" | ||
| 4 | + android:layout_height="match_parent"> | ||
| 5 | + | ||
| 6 | + <TextView | ||
| 7 | + android:layout_width="match_parent" | ||
| 8 | + android:layout_height="wrap_content" | ||
| 9 | + android:id="@+id/_cafelist" | ||
| 10 | + | ||
| 11 | + /> | ||
| 12 | + | ||
| 13 | +</LinearLayout> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + android:orientation="vertical" android:layout_width="match_parent" | ||
| 4 | + android:layout_height="match_parent"> | ||
| 5 | + | ||
| 6 | + <GridLayout | ||
| 7 | + android:layout_width="match_parent" | ||
| 8 | + android:layout_height="wrap_content" | ||
| 9 | + android:columnCount="2" | ||
| 10 | + android:orientation="horizontal" | ||
| 11 | + android:rowCount="4"> | ||
| 12 | + | ||
| 13 | + <TextView | ||
| 14 | + android:layout_width="match_parent" | ||
| 15 | + android:layout_height="match_parent" | ||
| 16 | + android:layout_columnSpan="2" | ||
| 17 | + android:gravity="center" | ||
| 18 | + android:text="List" | ||
| 19 | + android:textSize="30dp" | ||
| 20 | + /> | ||
| 21 | + | ||
| 22 | + <TextView | ||
| 23 | + android:layout_width="60dp" | ||
| 24 | + android:layout_height="50dp" | ||
| 25 | + android:layout_marginLeft="10dp" | ||
| 26 | + android:text="이름 : " | ||
| 27 | + android:textSize="20dp" | ||
| 28 | + android:layout_column="0"/> | ||
| 29 | + | ||
| 30 | + <TextView | ||
| 31 | + android:layout_width="200dp" | ||
| 32 | + android:layout_height="match_parent" | ||
| 33 | + android:layout_column="1" | ||
| 34 | + android:id="@+id/_name" | ||
| 35 | + /> | ||
| 36 | + | ||
| 37 | + <TextView | ||
| 38 | + android:layout_width="60dp" | ||
| 39 | + android:layout_height="50dp" | ||
| 40 | + android:layout_marginLeft="10dp" | ||
| 41 | + android:text="주소" | ||
| 42 | + android:textSize="20dp" | ||
| 43 | + android:layout_column="0"/> | ||
| 44 | + | ||
| 45 | + <TextView | ||
| 46 | + android:layout_width="200dp" | ||
| 47 | + android:layout_height="match_parent" | ||
| 48 | + android:layout_column="1" | ||
| 49 | + android:id="@+id/_address" | ||
| 50 | + /> | ||
| 51 | + | ||
| 52 | + <Button | ||
| 53 | + android:text="뒤로가기" | ||
| 54 | + android:id="@+id/btnBack" | ||
| 55 | + /> | ||
| 56 | + </GridLayout> | ||
| 57 | + | ||
| 58 | +</LinearLayout> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + android:orientation="vertical" android:layout_width="match_parent" | ||
| 4 | + android:layout_height="match_parent"> | ||
| 5 | + | ||
| 6 | + <TextView | ||
| 7 | + android:layout_width="match_parent" | ||
| 8 | + android:layout_height="wrap_content" | ||
| 9 | + android:id="@+id/_foodlist" | ||
| 10 | + | ||
| 11 | + /> | ||
| 12 | + | ||
| 13 | +</LinearLayout> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + android:orientation="vertical" android:layout_width="match_parent" | ||
| 4 | + android:layout_height="match_parent" | ||
| 5 | + android:id="@+id/dynamicArea"> | ||
| 6 | + | ||
| 7 | + <GridLayout | ||
| 8 | + android:layout_width="match_parent" | ||
| 9 | + android:layout_height="wrap_content" | ||
| 10 | + android:columnCount="2" | ||
| 11 | + android:orientation="horizontal" | ||
| 12 | + android:rowCount="4"> | ||
| 13 | + | ||
| 14 | + <TextView | ||
| 15 | + android:layout_width="match_parent" | ||
| 16 | + android:layout_height="match_parent" | ||
| 17 | + android:layout_columnSpan="2" | ||
| 18 | + android:gravity="center" | ||
| 19 | + android:text="List" | ||
| 20 | + android:textSize="30dp" | ||
| 21 | + /> | ||
| 22 | + | ||
| 23 | + <TextView | ||
| 24 | + android:layout_width="60dp" | ||
| 25 | + android:layout_height="50dp" | ||
| 26 | + android:layout_marginLeft="10dp" | ||
| 27 | + android:text="이름 : " | ||
| 28 | + android:textSize="20dp" | ||
| 29 | + android:layout_column="0"/> | ||
| 30 | + | ||
| 31 | + <TextView | ||
| 32 | + android:layout_width="200dp" | ||
| 33 | + android:layout_height="match_parent" | ||
| 34 | + android:layout_column="1" | ||
| 35 | + android:id="@+id/_name" | ||
| 36 | + /> | ||
| 37 | + | ||
| 38 | + <TextView | ||
| 39 | + android:layout_width="60dp" | ||
| 40 | + android:layout_height="50dp" | ||
| 41 | + android:layout_marginLeft="10dp" | ||
| 42 | + android:text="주소" | ||
| 43 | + android:textSize="20dp" | ||
| 44 | + android:layout_column="0"/> | ||
| 45 | + | ||
| 46 | + <TextView | ||
| 47 | + android:layout_width="200dp" | ||
| 48 | + android:layout_height="match_parent" | ||
| 49 | + android:layout_column="1" | ||
| 50 | + android:id="@+id/_address" | ||
| 51 | + /> | ||
| 52 | + | ||
| 53 | + <Button | ||
| 54 | + android:text="뒤로가기" | ||
| 55 | + android:id="@+id/btnBack" | ||
| 56 | + /> | ||
| 57 | + </GridLayout> | ||
| 58 | + | ||
| 59 | +</LinearLayout> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + android:orientation="vertical" android:layout_width="match_parent" | ||
| 4 | + android:layout_height="match_parent"> | ||
| 5 | + | ||
| 6 | + <TextView | ||
| 7 | + android:layout_width="match_parent" | ||
| 8 | + android:layout_height="wrap_content" | ||
| 9 | + android:id="@+id/_shoppinglist" | ||
| 10 | + | ||
| 11 | + /> | ||
| 12 | + | ||
| 13 | +</LinearLayout> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + android:orientation="vertical" android:layout_width="match_parent" | ||
| 4 | + android:layout_height="match_parent"> | ||
| 5 | + | ||
| 6 | + <GridLayout | ||
| 7 | + android:layout_width="match_parent" | ||
| 8 | + android:layout_height="wrap_content" | ||
| 9 | + android:columnCount="2" | ||
| 10 | + android:orientation="horizontal" | ||
| 11 | + android:rowCount="4"> | ||
| 12 | + | ||
| 13 | + <TextView | ||
| 14 | + android:layout_width="match_parent" | ||
| 15 | + android:layout_height="match_parent" | ||
| 16 | + android:layout_columnSpan="2" | ||
| 17 | + android:gravity="center" | ||
| 18 | + android:text="List" | ||
| 19 | + android:textSize="30dp" | ||
| 20 | + /> | ||
| 21 | + | ||
| 22 | + <TextView | ||
| 23 | + android:layout_width="60dp" | ||
| 24 | + android:layout_height="50dp" | ||
| 25 | + android:layout_marginLeft="10dp" | ||
| 26 | + android:text="이름 : " | ||
| 27 | + android:textSize="20dp" | ||
| 28 | + android:layout_column="0"/> | ||
| 29 | + | ||
| 30 | + <TextView | ||
| 31 | + android:layout_width="200dp" | ||
| 32 | + android:layout_height="match_parent" | ||
| 33 | + android:layout_column="1" | ||
| 34 | + android:id="@+id/_name" | ||
| 35 | + /> | ||
| 36 | + | ||
| 37 | + <TextView | ||
| 38 | + android:layout_width="60dp" | ||
| 39 | + android:layout_height="50dp" | ||
| 40 | + android:layout_marginLeft="10dp" | ||
| 41 | + android:text="주소" | ||
| 42 | + android:textSize="20dp" | ||
| 43 | + android:layout_column="0"/> | ||
| 44 | + | ||
| 45 | + <TextView | ||
| 46 | + android:layout_width="200dp" | ||
| 47 | + android:layout_height="match_parent" | ||
| 48 | + android:layout_column="1" | ||
| 49 | + android:id="@+id/_address" | ||
| 50 | + /> | ||
| 51 | + | ||
| 52 | + <Button | ||
| 53 | + android:text="뒤로가기" | ||
| 54 | + android:id="@+id/btnBack" | ||
| 55 | + /> | ||
| 56 | + </GridLayout> | ||
| 57 | + s | ||
| 58 | +</LinearLayout> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android"> | ||
| 3 | + <background android:drawable="@drawable/ic_launcher_background" /> | ||
| 4 | + <foreground android:drawable="@drawable/ic_launcher_foreground" /> | ||
| 5 | +</adaptive-icon> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android"> | ||
| 3 | + <background android:drawable="@drawable/ic_launcher_background" /> | ||
| 4 | + <foreground android:drawable="@drawable/ic_launcher_foreground" /> | ||
| 5 | +</adaptive-icon> | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
2.89 KB
4.79 KB
2.01 KB
2.72 KB
4.38 KB
6.73 KB
6.24 KB
10.2 KB
8.91 KB
14.8 KB
| 1 | +<resources> | ||
| 2 | + | ||
| 3 | + <!-- Base application theme. --> | ||
| 4 | + <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar"> | ||
| 5 | + <!-- Customize your theme here. --> | ||
| 6 | + <item name="colorPrimary">@color/colorPrimary</item> | ||
| 7 | + <item name="colorPrimaryDark">@color/colorPrimaryDark</item> | ||
| 8 | + <item name="colorAccent">@color/colorAccent</item> | ||
| 9 | + </style> | ||
| 10 | + | ||
| 11 | +</resources> |
Androidstudy_Project/app/src/test/java/com/example/androidstudy_project/ExampleUnitTest.java
0 → 100755
| 1 | +package com.example.androidstudy_project; | ||
| 2 | + | ||
| 3 | +import org.junit.Test; | ||
| 4 | + | ||
| 5 | +import static org.junit.Assert.*; | ||
| 6 | + | ||
| 7 | +/** | ||
| 8 | + * Example local unit test, which will execute on the development machine (host). | ||
| 9 | + * | ||
| 10 | + * @see <a href="http://d.android.com/tools/testing">Testing documentation</a> | ||
| 11 | + */ | ||
| 12 | +public class ExampleUnitTest { | ||
| 13 | + @Test | ||
| 14 | + public void addition_isCorrect() { | ||
| 15 | + assertEquals(4, 2 + 2); | ||
| 16 | + } | ||
| 17 | +} | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
Androidstudy_Project/build.gradle
0 → 100755
| 1 | +// Top-level build file where you can add configuration options common to all sub-projects/modules. | ||
| 2 | + | ||
| 3 | +buildscript { | ||
| 4 | + | ||
| 5 | + repositories { | ||
| 6 | + google() | ||
| 7 | + jcenter() | ||
| 8 | + } | ||
| 9 | + dependencies { | ||
| 10 | + classpath 'com.android.tools.build:gradle:3.3.2' | ||
| 11 | + | ||
| 12 | + | ||
| 13 | + // NOTE: Do not place your application dependencies here; they belong | ||
| 14 | + // in the individual module build.gradle files | ||
| 15 | + } | ||
| 16 | +} | ||
| 17 | + | ||
| 18 | +allprojects { | ||
| 19 | + repositories { | ||
| 20 | + google() | ||
| 21 | + jcenter() | ||
| 22 | + } | ||
| 23 | +} | ||
| 24 | + | ||
| 25 | +task clean(type: Delete) { | ||
| 26 | + delete rootProject.buildDir | ||
| 27 | +} |
Androidstudy_Project/gradle.properties
0 → 100755
| 1 | +# Project-wide Gradle settings. | ||
| 2 | +# IDE (e.g. Android Studio) users: | ||
| 3 | +# Gradle settings configured through the IDE *will override* | ||
| 4 | +# any settings specified in this file. | ||
| 5 | +# For more details on how to configure your build environment visit | ||
| 6 | +# http://www.gradle.org/docs/current/userguide/build_environment.html | ||
| 7 | +# Specifies the JVM arguments used for the daemon process. | ||
| 8 | +# The setting is particularly useful for tweaking memory settings. | ||
| 9 | +org.gradle.jvmargs=-Xmx1536m | ||
| 10 | +# When configured, Gradle will run in incubating parallel mode. | ||
| 11 | +# This option should only be used with decoupled projects. More details, visit | ||
| 12 | +# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects | ||
| 13 | +# org.gradle.parallel=true | ||
| 14 | + | ||
| 15 | + |
No preview for this file type
Androidstudy_Project/gradlew
0 → 100755
| 1 | +#!/usr/bin/env sh | ||
| 2 | + | ||
| 3 | +############################################################################## | ||
| 4 | +## | ||
| 5 | +## Gradle start up script for UN*X | ||
| 6 | +## | ||
| 7 | +############################################################################## | ||
| 8 | + | ||
| 9 | +# Attempt to set APP_HOME | ||
| 10 | +# Resolve links: $0 may be a link | ||
| 11 | +PRG="$0" | ||
| 12 | +# Need this for relative symlinks. | ||
| 13 | +while [ -h "$PRG" ] ; do | ||
| 14 | + ls=`ls -ld "$PRG"` | ||
| 15 | + link=`expr "$ls" : '.*-> \(.*\)$'` | ||
| 16 | + if expr "$link" : '/.*' > /dev/null; then | ||
| 17 | + PRG="$link" | ||
| 18 | + else | ||
| 19 | + PRG=`dirname "$PRG"`"/$link" | ||
| 20 | + fi | ||
| 21 | +done | ||
| 22 | +SAVED="`pwd`" | ||
| 23 | +cd "`dirname \"$PRG\"`/" >/dev/null | ||
| 24 | +APP_HOME="`pwd -P`" | ||
| 25 | +cd "$SAVED" >/dev/null | ||
| 26 | + | ||
| 27 | +APP_NAME="Gradle" | ||
| 28 | +APP_BASE_NAME=`basename "$0"` | ||
| 29 | + | ||
| 30 | +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||
| 31 | +DEFAULT_JVM_OPTS="" | ||
| 32 | + | ||
| 33 | +# Use the maximum available, or set MAX_FD != -1 to use that value. | ||
| 34 | +MAX_FD="maximum" | ||
| 35 | + | ||
| 36 | +warn () { | ||
| 37 | + echo "$*" | ||
| 38 | +} | ||
| 39 | + | ||
| 40 | +die () { | ||
| 41 | + echo | ||
| 42 | + echo "$*" | ||
| 43 | + echo | ||
| 44 | + exit 1 | ||
| 45 | +} | ||
| 46 | + | ||
| 47 | +# OS specific support (must be 'true' or 'false'). | ||
| 48 | +cygwin=false | ||
| 49 | +msys=false | ||
| 50 | +darwin=false | ||
| 51 | +nonstop=false | ||
| 52 | +case "`uname`" in | ||
| 53 | + CYGWIN* ) | ||
| 54 | + cygwin=true | ||
| 55 | + ;; | ||
| 56 | + Darwin* ) | ||
| 57 | + darwin=true | ||
| 58 | + ;; | ||
| 59 | + MINGW* ) | ||
| 60 | + msys=true | ||
| 61 | + ;; | ||
| 62 | + NONSTOP* ) | ||
| 63 | + nonstop=true | ||
| 64 | + ;; | ||
| 65 | +esac | ||
| 66 | + | ||
| 67 | +CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||
| 68 | + | ||
| 69 | +# Determine the Java command to use to start the JVM. | ||
| 70 | +if [ -n "$JAVA_HOME" ] ; then | ||
| 71 | + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||
| 72 | + # IBM's JDK on AIX uses strange locations for the executables | ||
| 73 | + JAVACMD="$JAVA_HOME/jre/sh/java" | ||
| 74 | + else | ||
| 75 | + JAVACMD="$JAVA_HOME/bin/java" | ||
| 76 | + fi | ||
| 77 | + if [ ! -x "$JAVACMD" ] ; then | ||
| 78 | + die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | ||
| 79 | + | ||
| 80 | +Please set the JAVA_HOME variable in your environment to match the | ||
| 81 | +location of your Java installation." | ||
| 82 | + fi | ||
| 83 | +else | ||
| 84 | + JAVACMD="java" | ||
| 85 | + which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||
| 86 | + | ||
| 87 | +Please set the JAVA_HOME variable in your environment to match the | ||
| 88 | +location of your Java installation." | ||
| 89 | +fi | ||
| 90 | + | ||
| 91 | +# Increase the maximum file descriptors if we can. | ||
| 92 | +if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then | ||
| 93 | + MAX_FD_LIMIT=`ulimit -H -n` | ||
| 94 | + if [ $? -eq 0 ] ; then | ||
| 95 | + if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then | ||
| 96 | + MAX_FD="$MAX_FD_LIMIT" | ||
| 97 | + fi | ||
| 98 | + ulimit -n $MAX_FD | ||
| 99 | + if [ $? -ne 0 ] ; then | ||
| 100 | + warn "Could not set maximum file descriptor limit: $MAX_FD" | ||
| 101 | + fi | ||
| 102 | + else | ||
| 103 | + warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" | ||
| 104 | + fi | ||
| 105 | +fi | ||
| 106 | + | ||
| 107 | +# For Darwin, add options to specify how the application appears in the dock | ||
| 108 | +if $darwin; then | ||
| 109 | + GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" | ||
| 110 | +fi | ||
| 111 | + | ||
| 112 | +# For Cygwin, switch paths to Windows format before running java | ||
| 113 | +if $cygwin ; then | ||
| 114 | + APP_HOME=`cygpath --path --mixed "$APP_HOME"` | ||
| 115 | + CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` | ||
| 116 | + JAVACMD=`cygpath --unix "$JAVACMD"` | ||
| 117 | + | ||
| 118 | + # We build the pattern for arguments to be converted via cygpath | ||
| 119 | + ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` | ||
| 120 | + SEP="" | ||
| 121 | + for dir in $ROOTDIRSRAW ; do | ||
| 122 | + ROOTDIRS="$ROOTDIRS$SEP$dir" | ||
| 123 | + SEP="|" | ||
| 124 | + done | ||
| 125 | + OURCYGPATTERN="(^($ROOTDIRS))" | ||
| 126 | + # Add a user-defined pattern to the cygpath arguments | ||
| 127 | + if [ "$GRADLE_CYGPATTERN" != "" ] ; then | ||
| 128 | + OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" | ||
| 129 | + fi | ||
| 130 | + # Now convert the arguments - kludge to limit ourselves to /bin/sh | ||
| 131 | + i=0 | ||
| 132 | + for arg in "$@" ; do | ||
| 133 | + CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` | ||
| 134 | + CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option | ||
| 135 | + | ||
| 136 | + if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition | ||
| 137 | + eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` | ||
| 138 | + else | ||
| 139 | + eval `echo args$i`="\"$arg\"" | ||
| 140 | + fi | ||
| 141 | + i=$((i+1)) | ||
| 142 | + done | ||
| 143 | + case $i in | ||
| 144 | + (0) set -- ;; | ||
| 145 | + (1) set -- "$args0" ;; | ||
| 146 | + (2) set -- "$args0" "$args1" ;; | ||
| 147 | + (3) set -- "$args0" "$args1" "$args2" ;; | ||
| 148 | + (4) set -- "$args0" "$args1" "$args2" "$args3" ;; | ||
| 149 | + (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; | ||
| 150 | + (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; | ||
| 151 | + (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; | ||
| 152 | + (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; | ||
| 153 | + (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; | ||
| 154 | + esac | ||
| 155 | +fi | ||
| 156 | + | ||
| 157 | +# Escape application args | ||
| 158 | +save () { | ||
| 159 | + for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done | ||
| 160 | + echo " " | ||
| 161 | +} | ||
| 162 | +APP_ARGS=$(save "$@") | ||
| 163 | + | ||
| 164 | +# Collect all arguments for the java command, following the shell quoting and substitution rules | ||
| 165 | +eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" | ||
| 166 | + | ||
| 167 | +# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong | ||
| 168 | +if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then | ||
| 169 | + cd "$(dirname "$0")" | ||
| 170 | +fi | ||
| 171 | + | ||
| 172 | +exec "$JAVACMD" "$@" |
Androidstudy_Project/gradlew.bat
0 → 100755
| 1 | +@if "%DEBUG%" == "" @echo off | ||
| 2 | +@rem ########################################################################## | ||
| 3 | +@rem | ||
| 4 | +@rem Gradle startup script for Windows | ||
| 5 | +@rem | ||
| 6 | +@rem ########################################################################## | ||
| 7 | + | ||
| 8 | +@rem Set local scope for the variables with windows NT shell | ||
| 9 | +if "%OS%"=="Windows_NT" setlocal | ||
| 10 | + | ||
| 11 | +set DIRNAME=%~dp0 | ||
| 12 | +if "%DIRNAME%" == "" set DIRNAME=. | ||
| 13 | +set APP_BASE_NAME=%~n0 | ||
| 14 | +set APP_HOME=%DIRNAME% | ||
| 15 | + | ||
| 16 | +@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||
| 17 | +set DEFAULT_JVM_OPTS= | ||
| 18 | + | ||
| 19 | +@rem Find java.exe | ||
| 20 | +if defined JAVA_HOME goto findJavaFromJavaHome | ||
| 21 | + | ||
| 22 | +set JAVA_EXE=java.exe | ||
| 23 | +%JAVA_EXE% -version >NUL 2>&1 | ||
| 24 | +if "%ERRORLEVEL%" == "0" goto init | ||
| 25 | + | ||
| 26 | +echo. | ||
| 27 | +echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||
| 28 | +echo. | ||
| 29 | +echo Please set the JAVA_HOME variable in your environment to match the | ||
| 30 | +echo location of your Java installation. | ||
| 31 | + | ||
| 32 | +goto fail | ||
| 33 | + | ||
| 34 | +:findJavaFromJavaHome | ||
| 35 | +set JAVA_HOME=%JAVA_HOME:"=% | ||
| 36 | +set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||
| 37 | + | ||
| 38 | +if exist "%JAVA_EXE%" goto init | ||
| 39 | + | ||
| 40 | +echo. | ||
| 41 | +echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||
| 42 | +echo. | ||
| 43 | +echo Please set the JAVA_HOME variable in your environment to match the | ||
| 44 | +echo location of your Java installation. | ||
| 45 | + | ||
| 46 | +goto fail | ||
| 47 | + | ||
| 48 | +:init | ||
| 49 | +@rem Get command-line arguments, handling Windows variants | ||
| 50 | + | ||
| 51 | +if not "%OS%" == "Windows_NT" goto win9xME_args | ||
| 52 | + | ||
| 53 | +:win9xME_args | ||
| 54 | +@rem Slurp the command line arguments. | ||
| 55 | +set CMD_LINE_ARGS= | ||
| 56 | +set _SKIP=2 | ||
| 57 | + | ||
| 58 | +:win9xME_args_slurp | ||
| 59 | +if "x%~1" == "x" goto execute | ||
| 60 | + | ||
| 61 | +set CMD_LINE_ARGS=%* | ||
| 62 | + | ||
| 63 | +:execute | ||
| 64 | +@rem Setup the command line | ||
| 65 | + | ||
| 66 | +set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||
| 67 | + | ||
| 68 | +@rem Execute Gradle | ||
| 69 | +"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% | ||
| 70 | + | ||
| 71 | +:end | ||
| 72 | +@rem End local scope for the variables with windows NT shell | ||
| 73 | +if "%ERRORLEVEL%"=="0" goto mainEnd | ||
| 74 | + | ||
| 75 | +:fail | ||
| 76 | +rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||
| 77 | +rem the _cmd.exe /c_ return code! | ||
| 78 | +if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 | ||
| 79 | +exit /b 1 | ||
| 80 | + | ||
| 81 | +:mainEnd | ||
| 82 | +if "%OS%"=="Windows_NT" endlocal | ||
| 83 | + | ||
| 84 | +:omega |
Androidstudy_Project/settings.gradle
0 → 100755
| 1 | +include ':app' |
-
Please register or login to post a comment