Skip to main content

Solution: react-native-maps showsUserLocation 동작 안함 해결 방법

Image result for MyLocationButton


react-navive-maps를 이용해서 지도를 구현하고 있는데 내 위치로 가기 버튼이 보이질 않았다.

First of all, a reminder: for the button to be visible, some criteria are needed (OK in the OP):
  • showsUserLocation must be set true because the default is false
  • showsMyLocationButton must stay true, as is the default
The issue is in a race condition between two asynchronous events: onMapReady and onLayout
(noted Ready and Layout, for short, below).
The decision to draw the button or not is done at the time of the Layout, and the setting of UserLocation can't be done before the Ready of the map (a handle to it is needed).
Unfortunately, usually, at launch, the Layout arrives before the Ready.

위 글을 참조해보면 showUserLocation과 showsMyLocationButton이 모두 true로 설정되어 있어야 하고, 

문제는 onMapReady과 onLayout의 동기화 문제라고한다.
버튼을 그릴지 말지가 Layout이 다 마무리 되는 시점에 결정되고 
유저의 위치는 맵이 다 준비 되어야만 작동을 하는데
일반적으로 맵이 다 준비되기 전에 Layout이 먼저 그려져 버려서 버튼이 안보이는 거라고 한다.

밑에 댓글들을 쭉보면 componentWillMount를 써서 맵이 다 그려진 뒤에 강제로 다시 그리게 하거나, 
Timeout을 주어서 topPadding이나 bottomPadding 혹은 width 같은걸 1px씩 이동했다가 
원 위치로 돌리는 등 아주 무식하고 기묘한 방법들을 많이 쓰신다...

나도 달리 방법이 없으니 여러 방법들을 시도해 보았는데 다 제대로 동작 안하다가 아래 해결방법이
구원해주셨다.
처음에 생성자에서 this.state에 flex를 넣어주고
componentDidMount에서 timeout을 주어서 500ms 후에 flex를 변경해준다.
그러면 맵 로딩 시간이 쪼끔 늘어나긴 하는데 맵을 repaint해주어서 userLocation버튼이 보인다!!
provider="google"이 필요하다는 글도 있으니 넣어주자.

The re-render workaround using padding property didn't work for me. I was able to make it work using the following approach:
  constructor(props) {
    super(props);
    this.state = {flex: 0};
  }
  componentDidMount(){
    setTimeout(()=>this.setState({flex: 1}),500);
  }
<MapView
        provider="google"
        style={{flex: this.state.flex}}
        showsMyLocationButton={true}
        showsUserLocation={true}
        followsUserLocation={true}
      />

reference - https://github.com/react-community/react-native-maps/issues/1033

Comments

Popular posts from this blog

ftp, sftp, ssh 차이점

telnet ==> ssh  ftp ==> sftp  p2p방식이라 보안에 취약한것이 아니라 telnet과 ftp 인 경우는 패킷을 캡쳐해서 보면, 평문이기 때문에 보여져서는 안될부분(패스워드, 계정 등)이 쉽게 노출된다. 이는 아주 큰 문제를 발생시킬 수 있다. 이런 취약점을 보안하기 위해서 telnet은 ssh로  f tp는 sftp로 암호화된 프로토콜 SSL을 사용하는게 좋다. 이렇게 하면 모든 패킷을 암호화 해서 주고 받으므로  패킷을 잡아내더라도 해독하는데 슈퍼컴퓨터로 1달 이상 걸리게 된다.  cf)  telnet 과 ftp의 차이 telnet: 쉘권한을 취득(ex. bash)하여 마치 로컬 컴퓨터를 다루는 것처럼  실행되는 접속 방법  ftp: 파일을 전송하기 위한 프로토콜.  telnet으로 파일 전송을 못하며(zmodem프로토콜을 사용하면 되지만, 엄청 느림) ftp로 시스템을 관리하거나 데몬을 띄우는 것은 불가능.  Reference https://wpengine.com/resources/how-to-access-wordpress-files-using-sftp/ https://www.linux.co.kr/home2/board/subbs/board.php?bo_table=linuxserver&wr_id=19987

우분투 18.04 react-native run-android 실행 시 javax.net.ssl.SSLException 에러

리엑트 네이티브를 시작했다. ( 참고 ) 기본 튜토리얼 에서  create-react-native-app 를 사용하는 예제는 쉽게 실행됐는데 바로 요놈! react-native-cli 를 써서  react- native init [프로젝트 이름]  로 실행하는 예제는 뭐가 문제인지 실행한번 하는데 엄청나게 애를 먹였다. 우선 리액트 공식 홈페이지에서 하라는데로 다 했다는 전제하에 참고하시면 된다. 나름 다 잘 따라했다고 생각했는데 문제는 자바(jdk)였다. JAVA_HOME 환경변수 설정이 안되어 있었다. 일단 초기에 echo $JAVA_HOME 이라고 쳤는데 아무 것도 안뜨면 환경변수 설정이 아예 안돼있는 것이다. 순서 대로 체크리스트를 만들어보자면, 1. jdk버전을 확인하자 Java Development Kit React Native requires a recent version of the Java SE Development Kit (JDK).  Download and install JDK 8 or newer  if needed. cd /usr/lib/jvm/ 를 하면 현재 설치된 jdk들을 확인 할 수 있다. jdk8 이상의 버전이 없다면 아래 명령어로 다운 받자 sudo add-apt-repository ppa:webupd8team/java sudo apt-get update sudo apt-get install oracle-java8-installer 2. JAVA_HOME 환경 변수를 등록하기 위해 cd ~ 를 하여 홈으로 이동하고 숨김 파일인 .bashrc를 수정하자. 튜토리얼에는  $HOME/.bash_profile 이라고 되어 있지만 18.04에서는 저 파일이 없어서 알아보니 bashrc를 수정하면 된다. 나는 vim을 쓰므로 vim .bashrc 라고 입력했다. nano나 다른 편집기를 사용해도 좋다. 그리고 아래 명령어를 .bas

[공유] Bat 파일 명령어 모음

도스창 : 윈도우화면>시작버튼>명령어입력 부분에서 cmd.exe를 실행  --> 까만색의 화면이 뜬다. 나는 이 화면을 편의상 도스창이라고 부르겠다.  이 도스창과 과거 DOS OS와는 상관이 없다. 단지 모양이 비슷할 뿐이다. Batch file과 Shell Script는 같은 용어이다. 단, Batch file : Microsoft에서 부르는 용어. Shell Script : Linux에서 부르는 용어. 아래의 모든 설명은 MS를 기준으로 설명한다. 배치파일은 텍스트 파일로써, Shell 프로그램에서 실행되는 명령어들과 조건문들의 내용을 담고 있다. 쉘프로그램이 배치파일을 실행시키면, 한줄 한줄씩 배치파일의 내용이 실행이된다. 배치파일의 종류는 확장자가 .bat 파일    :  cmd.exe 또는 command.com으로 실행시킬 수 있다.                           확장자가 .vbs 파일   :  cscript.exe 또는 wscript.exe로 실행시킬 수 있다.                           확장자가 .js  파일     :  cscript.exe 또는 wscript.exe로 실행시킬 수 있다.                           확장자가 .ps1 파일   :  powershell.exe로 실행시킬 수 있다.        bat 파일보다는, vbs 또는 js 파일에서 좀 더 많은 기능을 구현할 수 있으며, 가장 최근에 나온 파워쉘은 가장 많은 기능을 구현할 수 있다. Shell 프로그램들에는, cmd.exe, wscript.exe, cscript.exe, command.com 등의 파일이 있다. 이 프로그램들은 윈도우화면>시작버튼>명령어입력 부분에서 실행시키면 된다.           (단 cscript.exe는, 먼저 cmd.exe를 실행시킨 후의 도스창에서 실행시키면 된다.) cmd.exe :