Notice
Recent Posts
Recent Comments
Link
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 8 | 9 | 10 | 11 | 12 | 13 | 14 |
| 15 | 16 | 17 | 18 | 19 | 20 | 21 |
| 22 | 23 | 24 | 25 | 26 | 27 | 28 |
Tags
- DataAccess
- Machine Learning
- function
- Python
- hierarchical_clustering
- 덴드로그램
- pandas
- count()
- data
- string
- DataFrame
- nan
- 분류 결과표
- list
- numpy
- IN
- 최댓값
- 반복문
- len()
- 최솟값
- dendrogram
- Dictionary
- wcss
- sklearn
- elbow method
- append()
- insert()
- del
- matplotlib
- analizer
Archives
- Today
- Total
개발공부
[Android] GPS 위도, 경도 정보 받기, 권한 설정 본문
androidManifest.xml
아래 권한을 추가합니다.
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
MainActivity.java
package com.fullspringwater.location;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AlertDialog;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import android.Manifest;
import android.content.ActivityNotFoundException;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.net.Uri;
import android.os.Bundle;
import android.provider.Settings;
import android.util.Log;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
LocationManager locationManager;
LocationListener locationListener;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
locationManager = (LocationManager) this.getSystemService(LOCATION_SERVICE);
locationListener = new LocationListener() {
// 움직일 때 마다 location에 좌표정보를 담는다.
@Override
public void onLocationChanged(@NonNull Location location) {
Log.i("myLocation", "위도 : " + location.getLatitude());
Log.i("myLocation", "경도 : " + location.getLongitude());
}
};
if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
ActivityCompat.requestPermissions(MainActivity.this,
new String[]{Manifest.permission.ACCESS_FINE_LOCATION,
Manifest.permission.ACCESS_COARSE_LOCATION},
100);
return;
}
// LocationManager.GPS_PROVIDER
// locationRequest : 어느 시간 주기로 이동을 감지할 것인지 (ms)
// pendingIntent : 어느 거리만큼 이동했을 때 감지할 것인지 (m)
// 조건을 사용하지 않으려면 -1로 지정한다.
// 둘중 하나만 충족해도 update한다.
locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER,
3000,
3,
locationListener);
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
if(requestCode == 100){
// 권한 설정 여부
if (ActivityCompat.checkSelfPermission(MainActivity.this,
Manifest.permission.ACCESS_FINE_LOCATION) !=
PackageManager.PERMISSION_GRANTED &&
ActivityCompat.checkSelfPermission(MainActivity.this,
Manifest.permission.ACCESS_COARSE_LOCATION) !=
PackageManager.PERMISSION_GRANTED) {
// 권한 거부상태면 다이얼로그를 띄운다.
AlertDialog.Builder localBuilder = new AlertDialog.Builder(this);
localBuilder.setTitle("권한 설정")
.setMessage("권한을 설정하지 않으면 앱 사용이 불가능합니다.")
.setPositiveButton("권한 설정하러 가기", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
try {
Intent intent = new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS)
.setData(Uri.parse("package:" + getPackageName()));
startActivity(intent);
} catch (ActivityNotFoundException e){
e.printStackTrace();
Intent intent = new Intent(Settings.ACTION_MANAGE_APPLICATIONS_SETTINGS);
startActivity(intent);
}
}
})
.setNegativeButton("종료하기", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
// Toast.makeText(getApplication(), "제한됩니다.", Toast.LENGTH_SHORT).show();
finish();
}
}).create().show();
return;
}
// LocationManager.GPS_PROVIDER
// locationRequest : 어느 시간 주기로 이동을 감지할 것인지 (ms)
// pendingIntent : 어느 거리만큼 이동했을 때 감지할 것인지 (m)
// 조건을 사용하지 않으려면 -1로 지정한다.
// 둘중 하나만 충족해도 update한다.
locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER,
3000,
3,
locationListener);
}
}
}
실행화면

거부 눌렀을 때

권한 설정하기 눌렀을 때

여기서 권한 허용이 가능합니다.

권한 허용 후 로그캣

'Android' 카테고리의 다른 글
| [Firebase] Realtime DataBase를 사용하기 위한 환경 설정 (0) | 2022.09.16 |
|---|---|
| [Android] Retrofit2 라이브러리 form-data 형식 파일, 텍스트 전송하기(Multipart form 이용) (0) | 2022.07.26 |
| [Android] Progress Dialog 프로그레스 다이얼로그 생성/제거 (0) | 2022.07.25 |
| [Android] Retrofit2 라이브러리를 이용한 POST로 API 호출하여 처리하는 방법 (0) | 2022.07.21 |
| [Android] Retrofit2 라이브러리 사용을 위한 설정 방법 (0) | 2022.07.21 |