플러터에서 date picker를 기본 제공해 주고 있다.

정확히 말하면 flutter/material.dart에 showDatePicker함수가 

datepicker를 구현한다.

 

아래는 플러터사이트의 튜터리얼에 있는 사용법이다.

Future<DateTime> selectedDate = showDatePicker(
  context: context,
  initialDate: DateTime.now(),
  firstDate: DateTime(2018),
  lastDate: DateTime(2030),
  builder: (BuildContext context, Widget child) {
    return Theme(
      data: ThemeData.dark(),
      child: child,
    );
  },
);

 

이를 조금더 사용하기 쉽게 사용자 함수로 아래와 같이 만들었다.

return 값을 받는게 목적이다.

  Future selectDate() async {
    DateTime picked = await showDatePicker(
        context: context,
        locale: const Locale('ko', 'KO'),
        initialDate: DateTime.now(),
        firstDate: DateTime(2015),
        lastDate: DateTime(2030),
        builder: (BuildContext context, Widget child) {
          return Theme(
            data: ThemeData.dark(),
            child: child,
          );
        },
    );
    if(picked != null) {
      return picked.toString().substring(0, 10 );
    } else {
      return null;
    }
  }

 

버튼에 이벤트를 달아 실행하니

아래와 같은 에러가 발생했다.

 

 

 

에러 문구

The following NoSuchMethodError was thrown building Directionality(textDirection: ltr):
The method 'formatFullDate' was called on null.
Receiver: null
Tried calling: formatFullDate(Instance of 'DateTime')

 

formatFullDate라는 함수를 호출하면서 null 에러가 발생한것이다.

 

구글링 결과

국제 지역화 정보를 사용한다는 것을 셋팅하여야 한다는 것이다.

 

첫번째는 pubspec.yaml에서 페키지를 dependency 하고

main.dart에서 MateralApp에 localizationsDelegates 와 supportedLocales를 설정해 주면된다.

 

pubspec.yaml

  # lcalizations package
  flutter_localizations:
    sdk: flutter

 

main.dart

      child: MaterialApp(
          title: 'TEST APP',
          localizationsDelegates: [
            GlobalMaterialLocalizations.delegate,
            GlobalWidgetsLocalizations.delegate,
          ],
          supportedLocales: [
            const Locale('en', 'US'),
            const Locale('ko', 'KO'),
          ],

 

에뮬레이터 재시작을 하니 아주 예쁘게 달력이 출력된다.

 

 

테스트 결과 supportedLocales는 설정하지 않아도 달력이 정상적으로 출력된다.

한가지 아쉬운것은 달만 선택가능하는 기능을 제공하지 않는것이다.

 

플러터에서 문자열이 숫자형인지 체크하는 함수

플러터에서는 내장함수로 isNumeric, isNumber 와 같은 함수가 없어

사용자 정의 함수를 사용해야 함다.

 

인트형인지 체크

  bool isInt(String str) {
    if(str == null) {
      return false;
    }
    return int.tryParse(str) != null;
  }

str 이 null이면 인트형이 아님.

str을 tryParse해서 성고하면 숫자형 리턴, 실패하면 null 이 리턴되므로 null과 비교하여 성공여부 리턴한다.

즉, null 이면 인트형이 아니다.

 

더블형인지 체크

  bool isDouble(String str) {
    if(str == null) {
      return false;
    }
    return double.tryParse(str) != null;
  }

인트형 체크와 같다.

안드로이드 에뮬레이터를 처음 실행한 경우 키보드에 한글이 표시되지 않는다.

키보드에 영어만 표시되고 한글로 전환하는 지구모양의 아이콘이 표시되지 않는다.

 

 

영문,한글 전환 아이콘이 보이지 않는다.

한글을 사용할 수 있도록 설정화면으로 들어간다.

 

키보드에서 영문, 한글 선택 아이콘이 보이지 않는다.

 

설정 앱을 클릭하여 설정화면으로 이동한다.

시스템 항목으로 들어간다.

Language & Input 항목으로 들어간다.

 

Languages 항목으로 들어간다.

설정된 언어가 영어만 된것을 확인할 수 있다.

Add a lnaguage를 선택한다.

언어를 선택하면 되는데 한글은 가장 아래에 있어서 검색을 하는게 편하다.

돋보기 모양의 검색버튼을 클릭한다.

 

검색창에  kor을 입력하면 한국어가 검색된다.

한국어를 클릭한다.

한국어에는 두개가 보이는데 당연히 대한민국을 선택한다.

조선 어쩌고저쩌고는 왠지 무섭다.

한국어가 선택되면 기본 2번으로 셋팅된다.

오른쪽의 정렬 아이콘을 눌러 위로 올려준다.

그러면 한국어가 1번이 된다.

실행하는 앱으로 가보면 한글 키보드가 우선선택되는 것을 볼수 있다.

 

 

플러터에서 base64 문자열을 이미지로 표현하는 방식이다.

 

 

String base64 = '';

 

기존에는 

 

Image.memory(base64Decode(base64))

 

dart가 업데이트 된 이후인지 몰라도 해당 아래와 같이 코드가 오류가 발생했다.

Invalid character (at character 5)
data:image/png;base64,

 

아래와 같이 소스를 수정하여 에러를 수정했지만, 

 

Image.memory(Uri.parse(base64).data.contentAsBytes())

 

일시적인 오류인지 원인은 아직 파악을 하지 못했다.

 

Flutter 작업을 하면서 이런 저런 문제를 해결 하는 재미도 쏠쏠하다.

 

요즘 flutter로 앱을 개발하고 있는데.

스프링부트로 서버쪽을 API로 만들고

flutter 에서 앱을 만들어 API와 통신하는 형식으로 구성하였다.

 

그런데 안드로이드 에뮬레이터에서 

http://localhost:8080을 접속하면 

스프링부트에 로그가 남지 않는다.

 

위와 같이 접속 오류가 발생한다.

 

이유는 간단하다.

에뮬레이터도 하나의 OS로 localhost는 자기자신이다.

따라서 아이피는 자기 PC의 아이피로 설정해 주면 된다.

 

cmd에서 ipconfig명령으로 확인 할 수 있다.

http://192.100.100.25:8080 이런 식으로 설정하면 된다.

 

그럼데 팀단위 작업을 하면 개발자들의  아이피가 모두 다르므로 각각 설정하기가 귀찮다.

안드로이드 에뮬레이터에서는 

10.0.0.2를 이용하여 PC로 접근이 가능합니다.

따라서.

http://10.0.2.2:8080을 통해 개발팀 공통으로

자기 자신의 개발 PC로 접속이 가능합니다.

안드로이드 에뮬레이터를 실행하려면

안드로이드 스튜디오를 실행하고 AVD Manager를 실행하여 

에뮬레이터를 선택하여 실행하는 단계를 거쳐야 하는데요.

 

간단하게 CMD에서 에뮬레이터를 실행하는 법을 알아보겠습니다.

 

cmd 창에서

emulator -list-avds

를 실행하여 설치된 에뮬레이터 리스를 검색합니다.

 

현재 Pixel_2_API_28이라는 에뮬레이터 하나만 설치된 상황이네요.

 

에뮬레이터 명을 카피하고

emulator -avd Pixel_2_API_28

를 실행하면 안드로이드 에뮬레이터가 실행됩니다.

 

플러트 프로젝트를 깃허브에서 가져와서 비주얼스튜디오 코드로 열면

처음에는 엑박이 뜨는 경우가 있습니다.

플러터 프로젝트에서 쓰는 라이브러리가 없기 때문인데요.

 

 

해결 방법은

cmd 창에서

flutter packages get

명령을 실행하면 아래와 같이 필요한 라이브러리를 가져옵니다.

 

 

또는 라이브러리가 선언된 파일인

pubspec.yaml 파일을 열고

마우스 오른쪽  버튼을 클릭하여

Get Packages 메뉴를 클릭하면 라이브러리를 가져오게 됩니다.

 

 

 

이번 프로젝트에서 리액트 네이티브로 모바일을 개발하기로 되었다.

그래서 우선 React Native를 학습하면서 생기는 오류들을 정리하려고 한다.

 

1. 안드로이드로 실행 시 오류 - 구글 플레이 라이센스 문제

 

D:\test\reactnative\AwesomeProject>react-native run-android
info JS server already running.
info Building and installing the app on the device (cd android && gradlew.bat app:installDebug)...
Downloading https://services.gradle.org/distributions/gradle-5.4.1-all.zip
..............................................................................................................................

Welcome to Gradle 5.4.1!

Here are the highlights of this release:
 - Run builds with JDK12
 - New API for Incremental Tasks
 - Updates to native projects, including Swift 5 support

For more details see https://docs.gradle.org/5.4.1/release-notes.html

Starting a Gradle Daemon, 1 incompatible Daemon could not be reused, use --status for details

> Configure project :app
File C:\Users\kyoborealco\.android\repositories.cfg could not be loaded.
Checking the license for package Android SDK Build-Tools 28.0.3 in C:\tools\Android\sdk\licenses
Warning: License for package Android SDK Build-Tools 28.0.3 not accepted.

FAILURE: Build failed with an exception.

* What went wrong:
A problem occurred configuring project ':app'.
> Failed to install the following Android SDK packages as some licences have not been accepted.
     build-tools;28.0.3 Android SDK Build-Tools 28.0.3
  To build this project, accept the SDK license agreements and install the missing components using the Android Studio SDK Manager.
  Alternatively, to transfer the license agreements from one workstation to another, see http://d.android.com/r/studio-ui/export-licenses.html

  Using Android SDK: C:\tools\Android\sdk

* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.

* Get more help at https://help.gradle.org

BUILD FAILED in 1m 11s
error Could not install the app on the device, read the error above for details.
Make sure you have an Android emulator running or a device connected and have
set up your Android development environment:
https://facebook.github.io/react-native/docs/getting-started.html
error Command failed: gradlew.bat app:installDebug. Run CLI with --verbose flag for more details.

D:\test\reactnative\AwesomeProject>

 

구글 플레이 라이센스 문제로 android studio 에서 

Tools < SDK Manager 메뉴로 들어가서

SDK Tools 탭으로 이동하면 중간 쯤에 Google Play Licensing Library 항목이 있다.

이게 인스톨되지 않으면 생기는 오류이다.

해당 항목을 인스톨 하고 재실행하면 된다.

 

 

 

2. 안트로이드 버추어 디바이스 연결 불가 오류

 

D:\test\reactnative\AwesomeProject>react-native run-android
info JS server already running.
info Building and installing the app on the device (cd android && gradlew.bat app:installDebug)...
11:42:04 D/DeviceMonitor: Opening adb connection
> Task :app:installDebug FAILED

FAILURE: Build failed with an exception.

* What went wrong:
Execution failed for task ':app:installDebug'.
com.android.builder.testing.api.DeviceException: No connected devices!

* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more lo

* Get more help at https://help.gradle.org

Deprecated Gradle features were used in this build, making it incompatible with Gradle 6.0.
Use '--warning-mode all' to show the individual deprecation warnings.
See https://docs.gradle.org/5.4.1/userguide/command_line_interface.html#sec:command_line_warnings

BUILD FAILED in 2s
26 actionable tasks: 1 executed, 25 up-to-date
<-------------> 0% WAITING
> IDLE
error Could not install the app on the device, read the error above for details.
Make sure you have an Android emulator running or a device connected and have
set up your Android development environment:
https://facebook.github.io/react-native/docs/getting-started.html
error Command failed: gradlew.bat app:installDebug. Run CLI with --verbose flag for more details.

 

안드로이드 스튜디오 버추얼 디바이스가 실행되지 않아서 생긴문제이다.

안드로이드 스튜디오에서

Tools > AVD Manager 메뉴로 들어가면 Andriod Virtual Device Manager 창이 열리고 

여기서 디바이를 더블클릭하여 버츄어 디바이스 실행 후 

명령어를 실행하면 정상 작동된다.

 

+ Recent posts