본문 바로가기

전체 글30

[Flutter] http 통신(Post) 저번에 get 을 이용해서 서버에서 데이터를 가져오는 것을 해보았으니 이번에는 post를 이용해서 서버에 데이터를 보내는걸 해보도록 하겠습니다. TextEditingController TextField에서 작성한 값을 서버로 전송할 계획인데 이렇게 하기 위해서는 TextEditingController()를 이용해줘야합니다. final TextEditingController namecontroller = TextEditingController(); 이렇게 namecontroller를 선언해주고 나중에 TextField에서는 children: [ TextField( controller: namecontroller, decoration: const InputDecoration(hintText: 'Enter T.. 2023. 8. 26.
[Flutter] Listview.builder Listview.builder()는 동일한 형태의 view를 여러개 화면에 그릴때 효과적으로 사용할 수 있는 위젯입니다. 기본적으로 itemCount와 itemBuilder 속성이 필요합니다. itemCount는 용어 그대로 몇 개의 아이템을 표시할 것인지, itemBuilder는 어떤 view를 화면에 그릴지를 선택하는 속성입니다. itemCount : int값이며 ListView 항목들의 총개수에 해당한다. (단, 주어지지 않으면 무한히 항목을 만든다.) itemBuilder(BuildContext ctx, int i) : i번째에 해당하는 항목에 그려질 View를 반환하는 함수이다. idx는 0부터 시작. ListView.builder( itemCount: _riview.length, itemBui.. 2023. 8. 22.
[Flutter] http 통신(GET) & JSON 파싱 (2) 지난 포스팅에 이어 서버에서 가져온 데이터를 앱 화면에 보여지도록 해보겠습니다. 4. 데이터 Fetch fetchAlbum()메소드를 initState() or didChangeDependencies()에서 호출합니다. initState() 메소드는 한번 실행된 후 다시는 실행되지 않습니다. 따라서 InheritedWidget의 변화에 따라 API가 다시 로드 되는 것을 원한다면, fetchAlbum() 메소드를 didChangeDependencies()안에서 호출하고 그렇지 않다면 initState()에서 호출하면 됩니다. class _ListTileAppState extends State { late Future futureAlbum; //late : non-nullable 변수의 초기화를 나중에 할.. 2023. 8. 16.
[Flutter] http 통신(GET) & JSON 파싱 (1) 오늘은 서버에서 데이터를 가져와서 flutter 앱 화면에서 보이도록 해보겠습니다.(flutter 공식문서 내용을 참고하였습니다.) 1.  패키지를 추가합니다. pubspec.yaml는 플로터 프로젝트를 생성하면 같이 생기는 기본 파일로 패키지 의존성 관리 및 프로젝트 정의 등의 다양한 역할을 수행하는 파일입니다. 그중에 dependencies는 패키지의 의존성을 작성하는 곳으로 주로 외부 패키지를 가져다 쓰기 위해 사용되는데 이곳에 http 패키지를 추가해줍니다. 그리고 AndroidManifest.xml 파일에서 인터넷 권한을 추가해줘야합니다.  AndroidManifest.xml파일에 을 작성해줌으로써 앱에 인터넷 권한이 추가됩니다. http 패키지는 import 'package:.. 2023. 8. 15.
[Flutter] StatefulWidget vs StatelessWidget 앱 개발도중 기초적인 부분에서 헷갈려서 포스팅하면서 다시 한번 정리하고자합니다! Flutter에서는 화면에 무엇인가 표시하는 경우 모든 것을 Widget으로 처리합니다. 이러한 widget은 크게 StatefulWidget과 StatelessWidget 2개로 나뉩니다. 오늘은 이 두 위젯의 차이점에 대해 포스팅 하고자 합니다. Stateless Widget 화면이 로드될 때 한 번만 그려지는 State변경이 불가능한 위젯으로 변경이 필요한 Data가 없는 것을 의미하며 이벤트 또는 사용자 상호 작용에 의해 동작하지 않습니다. 쉽게 말하면 한번 빌드 된 이후로 그 위젯의 상태에 관여할 수 없습니다. 보통 아래와 같이 간단하게 선언됩니다. StatelessWidget을 상속하고, build() 함수를 @o.. 2023. 8. 14.
[Flutter] uses-sdk:minSdkVersion 16 cannot be smaller than version 19 오류 저는 플로터를 실행할때 플로터 자체에서 모바일로 볼 수 있도록 제공해주는 애뮬레이터를 사용하지않고 웹이나 윈도우에서 결과를 확인했습니다. 그러다가 어차피 앱을 만드는거니까 모바일 환경에서도 제대로 확인을 해보는게 좋겠다는 생각이들 어서 애뮬레이터를 생성하고 실행 해보았습니다. 그런데 uses-dk:minSdkVersion 16 cannot be smaller than version 19로 시작하는 장문의 에러가 발생하였습니다. 찾아보니까 flutter에서 빌드 시, 특정 라이브러리가 minsdk버전을 충족하지 못하면 위와 같은 에러가 발생하고 minSdkVersion을 올려야 한다는 사실을 알게되었습니다. 그래서 어디서 버전을 올릴 수 있나 하고 찾아봤는데 android/app/build.gradle 파.. 2023. 8. 13.
[Flutter]TextFormField 꾸미기 지난번 포스팅때 아래와 같은 TextFormField를 구현하였습니다. 정상적으로 작동하긴하지만 테두리가 아래에만 있어서 내용을 담을 수 있는 칸 같지도 않고 버튼도 기본 스타일이라 별로 이쁘지 않습니다. 그래서 TextFormField의 몇가지 기능을 사용해서 화면을 꾸며보도록 하겠습니다. autovalidateMode 사용자 입력 값을 onSaved() 호출할 때 validation 할지, 변경할 때마다 항상 validation을 할지 설정합합니다. AutovalidationMode.always로 설정하면 onChange()를 별도로 처리할 필요 없이 사용자가 입력할 때마다 validation을 진행합니다. maxLines 텍스트필드의 최대 줄 수를 지정해 줍니다. cursorColor cursor의.. 2023. 8. 13.
[Flutter]TextFormField와 Form을 통한 사용자 입력 값 받기 TextFormField는 텍스트를 입력하고 입력한 텍스트를 저장 및 유효성 검사를 하기 위한 위젯으로 Form 과 함께 많이 사용합니다. 먼저 TextFormField를 사용하기 위한 방법에 대해서 알아보도록 하겠습니다. 1. Globalkey로 Form 만들기 Form 위젯은 여러 양식 필드를 그룹화하고 유효성을 검사하기 위한 컨테이너 역할을 합니다. 양식을 만들때 GlobalKey를 이용하여 Form을 고유하게 식별하고 이후에 여러 양식 필드의 유효성을 검사할 수 있습니다. GlobalKey는 요소를 식별하고 다른 키로의 액세스를 제공한다고 합니다. 그리고 상위 위젯에 적용했을 시 하위 위젯에까지 적용이 된다고 합니다. 저는 Form에 글로벌키를 사용하고, 하위 위젯인 TextFormField의 유.. 2023. 8. 12.