플러터를 배우게되면 StatelessWidget, StatefulWidget 이 두 형태로 위젯을 만드는 것을 이해하게 됩니다.

저도 물론 마찬가지로 이 두 가지를 다음과 같은 상황에 따라 사용하게 됩니다.

 

StatelessWidget : 내부 로직에서 상태변화가 일어나지 않는 경우 사용

StatefulWidget : 내부 로직에서 상태변화가 일어나는 경우 사용

 

상태변화가 일어난다는 것은 'int count'라는 프로퍼티가 있고,

Text위젯을 사용해서 현재 'count'가 가지고 있는 값을 표출할 때,

'count'값이 늘어나거나 감소하는 경우 상태변화가 일어난다고 합니다.

 

이렇게 변화된 값을 표출하기 위해서는 StatefulWidget에서 제공하는 

setState 함수를 사용하여 위젯을 재빌드하고 변경된 값을 보여주게 됩니다.

 

StatelessWidget에서는 애초에 값 변화가 없는 경우 선택을 하지만,

때로는 그렇지 않은 경우도 있습니다.

 

- 앱을 보수하거나 기능을 추가가 필요한 경우

- 부모 클래스가 StatelessWidget으로 선언된 경우

- 다이얼로그에서 사용이 필요한 경우

등.. 값을 갱신해주는 것이 필요할 때가 있습니다.

 

 

좀 더 플러터에 대해서 다양한 기능을 사용해보았다면,

HeritedWidget, Selector, Consumer위젯 등을 사용해서 표현할 수 있지만,

더욱 간단한 방법을 플러터 팀에서 제공해주고 있습니다.

 

그 위젯의 이름은 바로 'StatefulBuilder' 위젯입니다.

저같은 경우 다이얼로그에서 필요하여 사용하였었습니다.

 

코드를 살펴보면 StatefulBuilder위젯의 하위에 값의 변화가 필요한 위젯을 선언해줍니다.

그리고 setState함수를 커스텀 위젯으로 전달하여 사용합니다.

 

위의 코드에서는 EditingTextController에서 이벤트가 발생할 때마다 UI가 재빌드되도록 해주었네요.

StatelessWidget에서 곧 바로 StatefulWidget으로 바꾸어도 좋지만,

더 큰 보수가 들어가거나 어쩔 수 없는 경우 StatefulBuilder를 사용하여 UI를 재빌드해주도록 합니다 !

 

감사합니다🥦

 

 

링크 : https://api.flutter.dev/flutter/widgets/StatefulWidget-class.html

Flutter로 모바일 개발을 하게되면 Scaffold라는 위젯으로 UI구조의 시작을 알리게 됩니다.

네이티브로 UI를 구성하게 되면 일일히 구분해주었던 영역을 Scaffold위젯하나로 정리를 하게되니,

저로써는 너무나 편리하게 느껴지는데요. 여러분도 그러실까요?

 

하지만 Scaffold로 위젯의 구조를 정해주게될 때, appBar파라메터를 설정해주지 않게 되면,

다음과 같이 상단에 시계색상과 네트워크 상태 색상이 보이지 않게 됩니다.

 

상단을 보시면 플러터 로고는 보이지만 그외 색상은 현재 보이지 않습니다.

(상단바의 이름은 상단 네비게이션바, status바 등 이름으로 불립니다.

플러터에서는 statusBar라고 불리지만, 이해하기 쉽도록 다양한 이름을 같이 부르도록 할게요)

위 화면의 코드는 다음과 같이 이루어져 있습니다.

 

쭉 ~ child를 따라가다보면 Scaffold가 보이실 텐데요.

그 하단에 SafeArea가 있고 이후 임의로 정의된 위젯들이 선언되어 있습니다.

 

그럼, 상단의 상태값들이 보이게 수정해보도록 하겠습니다.

 

상단 상태(statusBar, top navigation bar)보이도록 수정

appBar파라메터를 정의해주지 않고 body파라메터에만 위젯을 설정해주는 경우만 해당됩니다.

우선 AnnotatedRegion이라는 위젯으로 body의 위젯들을 감싸줍니다.

 

그리고 상단의 상태바의 색상을 지정해주는데요.

가장, 중요한 왜? 왜? 상태바의 색상이 안보이느냐? 의 대한 대답은

색상이 현재 System Brightness자체의 색상으로 보여지고 있기 때문입니다.

'다크 모드'라고 들어보셨을까요?

스마트폰에 기본 모드는 밝지만, 다크모드는 어두운 분위기를 띄게 되는데요.

 

바로, 네비게이션 상단 바의 색상은 기본 모드이기 때문에 흰 색 글씨로 보이게 되는 것 입니다.

자세히 보시면 흰 색으로 얼핏 보이는 것을 알 수 있습니다.

 

 

이런 현상을 해결하기 위해서는 상단바의 색상을 다크모드로 변경해주어야 합니다.

(따로 임의의 색상을 설정하는 기능이 없기 떄문입니다)

 

먼저, 현재 다크모드인지 확인해주는 bool프로퍼티를 생성합니다.

(build안에서 또는 initState하는 시점에 생성해주세요^^)

@override 
Widget build(BuildContext context) {
  bool isDarkMode = MediaQuery.of(context).platformBrightness == Brightness.dark;
  
  return Scaffold(
    ...
  )
}

 

AnnotatedRegion위젯으로 body하위 위젯을 감싸줍니다.

return Scaffold(
  body: AnnotatedRegion<SystemUiOverlayStyle>(
    value: SystemUiOverlayStyle(
      ...
    ),
    child: SafeArea(
      ...
    )
  )
)

 

SystemUiOverlayStyle 파라메터를 살펴보겠습니다.

- statusBarColor : 상단 네비게이션바의 배경색상

- statusBarIconBrightness : 시간, 와이파이, 배터리 상태를 Icon으로 표현합니다. 

 

statusBarColor는 기본 primary색상이 적용되어 지정해주지 않아도 되지만,

보통 Scaffold의 배경색상을 White로 설정하면 이질감이 있기 떄문에 투명하게 지정해주는 것을 추천합니다.

 

statusBarIconBrightness현재 '기본모드' 이기 때문에 '다크모드'로 변형해주어야 글자가 보인다는 것

앞의 내용을 이해했다면 생각할 수 있습니다.

 

아래와 같이 설정해주도록 하겠습니다.

AnnotatedRegion<SystemUiOverlayStyle>(
  value: SystemUiOverlayStyle(
    statusBarColor: Colors.transparent,
    statusBarIconBrightness: isDarkMode ? Brightness.light : Brightness.dark
  )
)

 

결과는?

 

위 상단의 글자가 이제 식별이 되는 것을 볼 수 있습니다.

 

상단 네비게이션의 글자가 보이지 않는다고해서 당황하지마시고,

차근차근 위의 설명을 토대로 만들어가시면 되겠습니다.

 

감사합니다🍸

제가 정말 좋아하는 툴(IDE)인 Android Studio!

처음 Java언어로 프로그래밍을 시작하셨던 분들은 아마 Eclipse를 많이 사용하셨을텐데요.

Android OS개발을 하게 되면서 사용하게 되었는데, 정말 엄청나게 편리한 툴입니다 !

(다시 Eclipse를 사용하여 개발하는 것은 꿈에서도 꿀 수 없는 일이 되어버렸어요)

 

첫 포스팅으로 별거 아니지만 Android Studio 코드 스니펫안에 있는 라인선을 설정하는 방법을 공유하려 합니다.

 

 

빨간선 끝에 희미~한 선이 하나 보이시죠?

해당 라인에 따라 이쁘게 코드를 정렬하기 위해 있는 것인데요.

그것은 나중에 코드를 다시 보았을 때 식별하기 좋게하기 위함도 있어요.

 

하지만 저 라인선이 너무 좁게 느껴졌을때 늘일 수 있는 방법을 공유하려합니다.

 

File / Settings 로 이동하여 클릭합니다.

 

 

Editor / Code Style / Hard wrap at: 에서 Hard wrap at를 조절해주시면 됩니다.

 

 

하지만, 만약에 Flutter를 개발하고 계신다면 바뀌지 않을텐데요.

놀라지마시고 다시 좌측의 Code Style의 항목을 확인해보시죠 !

 

Editor / Code Style / Dart 를 보면 Line length가 "80"으로 설정되어 있는 것을 볼 수 있습니다.

해당 길이를 원하는 만큼 조절하시면 라인선의 위치가 바뀌는 것을 확인할 수 있어요 !

 

 

저는 사실 제가 개인적으로 기억하고 싶은 글들을

블로그에 저장소처럼 마구잡이로 올리곤 했었는데요.

 

앞으로는 그 정보들을 압축하여 공유하는 것에 힘을 쏟도록 하려해요.

도움이 되셨길 바라며 안드로이드 스튜디오의 스니펫 속의 라인선(말이 길죠~?)을 

조절하는 방법을 함께 알아가보았습니다.

 

감사합니다🌱

+ Recent posts