Giter Site home page Giter Site logo

sesac-slp's Introduction

SeSAC-SLP

SLP 사용 영상
클릭하면 유튜브 동영상으로 재생됩니다.

프로젝트 개요

사용자의 위치를 기반으로, 취미가 같은 친구를 찾을 수 있는 애플리케이션을 실 서비스를 진행 할 수 있는 완성도로 만드는 프로젝트입니다.

프로젝트 기간 : 2022. 01. 17 ~ 2022. 02. 26

프로젝트 진행 방식

애플리케이션의 디자인, 기획, 백엔드 서버가 준비된 상태에서 각각의 디자인과 기획에 맞는 아키텍쳐와 기능을 스스로 찾아 구현하는 식으로 진행했습니다. 애플리케이션은 전적으로 개인이 구현하지만 4인 구성의 팀을 구성하여 매일 3회 데일리 스크럼을 통해 사용 기술 및 진행상황 공유, 계획 수립, 회고를 진행하였습니다.

사용 기술 스택

  • MVVM, RxSwift, RxCocoa
  • Moya, Socket.IO
  • StoryBoard, SnapKit, SkeletonView, TabMan, RangeSeekSlider, Toast-Swift, ModernCollectionView
  • Realm
  • StoreKit, MapKit, Core Location, FirebaseAuth, FirebaseCloudMessaging , UserNotification

회고

지금까지 진행한 프로젝트 중에 가장 규모가 큰 프로젝트였고 배운게 정말 많은 프로젝트였다.
기술적으로 가장 많이 배운 점은, 당장 생각 나는 것들은 백엔드 서버와의 통신을 하며 생길 수 있는 다양한 변수들을 어떻게 사용자 경험을 고려하여 해결할수 있을까? 하는 점, 리터럴 사용을 최대한 줄이고 열거형을 사용하여 코드의 안정성과 확장성을 지킬 수 있는 방법들, UI를 커스텀, 모듈화 하여 애플리케이션의 일관된 디자인을 생산성 있게 유지하는 방법들이 있겠다.
가장 아쉬웠던 점은 기획의 내용을 구현하기에 급해 큰 그림을 그리지 못했던 것 같다. 아키텍쳐에 보다 신경 쓰지 못한 점, 프로토콜을 적절하게 활용하지 못한 점 등이 있다. 이러한 부분들은 더 학습하여 출시 앱을 비롯한 프로젝트에 적용해 볼 계획이다.


상세 리뷰, 이슈 및 해결

회원가입

| |

  • Architecture
    • 회원가입의 경우 모든 뷰를 MVVM 아키텍쳐와 RxSwift의 Input/Output 구조를 사용하여 구현하였다. 모든 텍스트 필드와 버튼은 커스텀 클래스를 만들어 디자인에 맞게 모듈화를 했다.
  • Custom View
    • 텍스트 필드는 editing의 여부와 user interaction의 success, error에 따라 설정이 바뀔 수 있게하였다. 커스텀 버튼의 경우 UIbutton configuration과 UIControl.State의 값들을 각각 설정하여 커스텀 클래스를 구현했다.
  • Validation
    • 전화번호, 이메일의 경우 String struct의 Extension을 통해 정규표현식을 활용하여 유효성 검사를 하였다.
  • Service
    • 성별 선택화면의 경우 성별을 선택하지 않아도 회원가입 진행이 되는데 이는 남/여 성별만 선택 가능할 경우 앱스토어 심사에서 리젝되는 이슈가 있기 떄문이다. 그러나 추후 성별 선택 없이 친구찾기를 진행 할 경우 회원정보 변경을 필요로 하게 하는 식으로 로직이 설정된다. 해당 프로젝트가 Service Level Project로 명명되는 납득할만한 로직중 하나라고 생각한다.

|

  • MapView
    • CLLocationManager를 통해 사용자의 위치권한을 확인한다. MapView의 기본, 최대, 최소 축척을 설정하여 최대한 사용하기 편한 지도를 만들었다. 사용자가 맵을 움직일때 마다 서버와 통신하여 지도 기준 친구를 찾고있는 친구들을 CustomAnnotation으로 보여준다. 이때 좌측 상단의 스위치를 통해 친구의 성별을 설정할 수 있다.
  • UserDefaults
    • 우측 하단의 플로팅 버튼을 통해 친구를 찾을 수 있는데 사용자의 상태에 따라(Default, 친구를 찾는 중, 매칭 완료) 플로팅 버튼의 이미지와 클릭하였을 때 이동하는 뷰가 다르다. UserDefaults의 값을 RxSwift를 활용 Observe 하는 방식으로 플로팅버튼의 이미지와 액션을 비동기로 바꿔준다.
    • 프로젝트의 DB는 Realm을 사용한 채팅을 제외하고 전부 UserDefaults가 사용되었다. 저장이 필요한 데이터의 양이 많지 않고 Property Wrapper를 학습하기 위해서였다. 모든 UserDefaults는 Property Wrapper로 사용성을 높였다. Struct까지 이를 적용한 점이 특히 편했다.

친구 찾기

| |

  • Modern CollectionView
    • 사용되는 모든 CollectionView는 DiffableDataSource와 SnapShot, CompositionalLayout이 사용된 ModernCollectionView를 적용하였다. 이를 학습하며 Expandable한 카드뷰에 적용하느라 프로젝트 첫 두번째 주 한주를 통째로 사용했다. 계획했던 것보다 훨씬 많은 시간을 쓰는 바람에 마음이 급해져 회원가입이 끝난후 부터 아키텍쳐를 전혀 신경쓰지 못한 채 구현과 기술 사용에 급급한 프로젝트가 되어버린것 같아 아쉽다. 사실 ModernCollectionView 자체는 학습에 오랜 시간이 필요한 내용이 아니라고 생각한다. 그러나 이를 각각의 셀이 컬렉션뷰인 컬렉션뷰로 만들다 보니 레이아웃이 잡히고, 데이터가 입력되는 주기에 맞춰 동적인 레이아웃이 설정되게 하는것이 내겐 어려운 지점이었다. 결과적으로는 원하는 카드뷰를 구현하긴 했지만 레이아웃 오류가 조금은 있는 상태에서 타협한 채로 프로젝트를 이어서 진행했다. ModernCollectionView를 학습하며 WWDC, 스택오버플로우, 블로그 등등 도움이 많이 되었지만 가장 도움이 되었던 건 Apple 문서의 예제 프로그램이었다.

인앱 구매

| |

  • StoreKit
    • StoreKit을 사용한 인앱 구매 화면이다. 앱스토어뿐 아니라 서버와의 Receipt Validation이 진행된다.
  • UI/UX
    • 앱스토어로부터 프로덕트를 불러오는 시간이 생각보다 오래 걸려서 기획에는 없던 내용이지만 SkeletonView를 적용하였다.
    • 새싹찾기 뷰와 스토어 모두 TabMan 라이브러리를 활용하여 뷰컨트롤러를 전환하는 식으로 구현했다.

Push Notification

|

  • Push Notification
    • 친구 찾기를 걸어놓고 상대방이 나에게 요청을 할 때, 내가 상대에게 요청을 하고 상대가 수락을 할 때, 매칭이 된 이후 채팅이 올 때 각각 서버로부터 Push Notification이 온다.
  • Life Cycle, View Hierarchy
    • 푸쉬를 클릭 했을 때 애플리케이션이 백그라운드 상태 일 경우와 사용중인 경우, 사용중일 경우 현재 위치해 있는 뷰에 따라, 그리고 상대와 나의 매칭 상태에 따라 각각의 푸쉬에 맞는 화면으로 전환해 준다.
    • 현재 탑뷰를 구하는 메서드, 루트뷰를 구하는 메서드, 그리고 뷰를 푸쉬하면서 네비게이션 스택에 뷰들을 넣어주는 식으로 뷰를 자연스럽게 전환 했다.
    • 요청 푸쉬를 받은 후 새싹찾기뷰에서 '받은요청' 탭으로 넘어가는 부분에서 Tabman에 마땅한 메서드가 없어서 헤맸는데 isPushed 라는 프로퍼티를 플래그로 설정하여 defaultPage를 결정하는 방식으로 간단하게 해결했다.

채팅

| |

  • Realm
    • 채팅이 시작되면 상대와의 대화를 Realm을 통해 불러오고 DB에 저장된 마지막 대화 이후의 대화를 서버로부터 받아온다. Socket.IO 라이브러리를 사용하여 실시간 소켓통신으로 채팅이 진행되며 모든 주고받는 채팅은 DB에 저장 된 후 뷰로 불러온다. Realm의 Notification token을 사용하여 구현했다.
  • Custom View
    • 우측 상단의 ellipsis 버튼을 클릭했을 때 카카오톡의 새로운 채팅 버튼을 클릭할 때 처럼 만들고 싶었다. 마땅한 라이브러리나 레퍼런스가 없어 무식하게 접근했다. 버튼목록의 y값에 CGAffineTransform을 통해 -200을 줘서 화면 위로 보내놓고 ellipsis 버튼을 클릭하면 origin으로 복귀 시키는 식으로 구현했다.
      결과
      예시

sesac-slp's People

Contributors

sehunkang avatar

Watchers

 avatar

sesac-slp's Issues

상세리뷰

회원가입

| |

회원가입의 경우 모든 뷰를 MVVM 아키텍쳐와 RxSwift의 Input/Output 구조를 사용하여 구현하였다. 모든 텍스트 필드와 버튼은 커스텀 클래스를 만들어 디자인에 맞게 모듈화를 했다.
텍스트 필드는 editing의 여부와 user interaction의 success, error에 따라 설정이 바뀔 수 있게하였다. 커스텀 버튼의 경우 UIbutton configuration과 UIControl.State의 값들을 각각 설정하여 커스텀 클래스를 구현했다.
전화번호, 이메일의 경우 String struct의 Extension을 통해 정규표현식을 활용하여 유효성 검사를 하였다.
성별 선택화면의 경우 성별을 선택하지 않아도 회원가입 진행이 되는데 이는 남/여 성별만 선택 가능할 경우 앱스토어 심사에서 리젝되는 이슈가 있기 떄문이다. 그러나 추후 성별 선택 없이 친구찾기를 진행 할 경우 회원정보 변경을 필요로 하게 하는 식으로 로직이 설정된다. 해당 프로젝트가 Service Level Project로 명명되는 납득할만한 로직중 하나라고 생각한다.

|

CLLocationManager를 통해 사용자의 위치권한을 확인한다. MapView의 기본, 최대, 최소 축척을 설정하여 최대한 사용하기 편한 지도를 만들었다. 사용자가 맵을 움직일때 마다 서버와 통신하여 지도 기준 친구를 찾고있는 친구들을 CustomAnnotation으로 보여준다. 이때 좌측 상단의 스위치를 통해 친구의 성별을 설정할 수 있다.
우측 하단의 플로팅 버튼을 통해 친구를 찾을 수 있는데 사용자의 상태에 따라(Default, 친구를 찾는 중, 매칭 완료) 플로팅 버튼의 이미지와 클릭하였을 때 이동하는 뷰가 다르다. UserDefaults의 값을 RxSwift를 활용 Observe 하는 방식으로 플로팅버튼의 설정을 비동기로 처리한다.
프로젝트의 DB는 Realm을 사용한 채팅을 제외하고 전부 UserDefaults가 사용되었다. 저장이 필요한 데이터의 양이 많지 않고 Property Wrapper를 학습하기 위해서였다. 모든 UserDefaults는 Property Wrapper로 사용성을 높였다. Struct까지 이를 적용한 점이 특히 편했다.

친구 찾기

| |

사용되는 모든 CollectionView는 DiffableDataSource와 SnapShot, CompositionalLayout이 사용된 ModernCollectionView를 적용하였다. 이를 학습하며 Expandable한 카드뷰에 적용하느라 프로젝트 첫 두번째 주 한주를 통째로 사용했다. 계획했던 것보다 훨씬 많은 시간을 쓰는 바람에 마음이 급해져 회원가입이 끝난후 부터 아키텍쳐를 전혀 신경쓰지 못한 채 구현과 기술 사용에 급급한 프로젝트가 되어버린것 같아 아쉽다. 사실 ModernCollectionView 자체는 학습에 오랜 시간이 필요한 내용이 아니라고 생각한다. 그러나 이를 각각의 셀이 컬렉션뷰인 컬렉션뷰로 만들다 보니 레이아웃이 잡히고, 데이터가 입력되는 주기에 맞춰 동적인 레이아웃이 설정되게 하는것이 내겐 어려운 지점이었다. 결과적으로는 원하는 카드뷰를 구현하긴 했지만 레이아웃 오류가 조금은 있는 상태에서 타협한 채로 프로젝트를 이어서 진행했다. ModernCollectionView를 학습하며 WWDC, 스택오버플로우, 블로그 등등 도움이 많이 되었지만 가장 도움이 되었던 건 Apple 문서의 예제 프로그램이었다.

인앱 구매

| |

StoreKit을 사용한 인앱 구매 화면이다. 앱스토어뿐 아니라 서버와의 Receipt Validation이 진행된다. 앱스토어로부터 프로덕트를 불러오는 시간이 생각보다 오래 걸려서 기획에는 없던 내용이지만 SkeletonView를 적용하였다.
새싹찾기 뷰와 스토어 모두 TabMan 라이브러리를 활용하여 뷰컨트롤러를 전환하는 식으로 구현했다.

Push Notification

|

친구 찾기를 걸어놓고 상대방이 나에게 요청을 할 때, 내가 상대에게 요청을 하고 상대가 수락을 할 때, 매칭이 된 이후 채팅이 올 때 각각 서버로부터 Push Notification이 온다.
푸쉬를 클릭 했을 때 애플리케이션이 백그라운드 상태 일 경우와 사용중인 경우, 사용중일 경우 현재 위치해 있는 뷰에 따라, 그리고 상대와 나의 매칭 상태에 따라 각각의 푸쉬에 맞는 화면으로 전환해 준다.
현재 탑뷰를 구하는 메서드, 루트뷰를 구하는 메서드, 그리고 뷰를 푸쉬하면서 네비게이션 스택에 뷰들을 넣어주는 식으로 뷰를 자연스럽게 전환 했다.
요청 푸쉬를 받은 후 새싹찾기뷰에서 '받은요청' 탭으로 넘어가는 부분에서 Tabman에 마땅한 메서드가 없어서 헤맸는데 isPushed 라는 프로퍼티를 플래그로 설정하여 defaultPage를 결정하는 방식으로 간단하게 해결했다.

채팅

| |

채팅이 시작되면 상대와의 대화를 Realm을 통해 불러오고 DB에 저장된 마지막 대화 이후의 대화를 서버로부터 받아온다. Socket.IO 라이브러리를 사용하여 실시간 소켓통신으로 채팅이 진행되며 모든 주고받는 채팅은 DB에 저장 된 후 뷰로 불러온다. Realm의 Notification token을 사용하여 구현했다.
우측 상단의 ellipsis 버튼을 클릭했을 때 카카오톡의 새로운 채팅 버튼을 클릭할 때 처럼 만들고 싶었다. 마땅한 라이브러리나 레퍼런스가 없어 무식하게 접근했다. 버튼목록의 y값에 CGAffineTransform을 통해 -200을 줘서 화면 위로 보내놓고 ellipsis 버튼을 클릭하면 origin으로 복귀 시키는 식으로 구현했다.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.