Skip to content

Latest commit

 

History

History
207 lines (160 loc) · 11.4 KB

README.md

File metadata and controls

207 lines (160 loc) · 11.4 KB

🎤 HYPE VOICE - 성우 지망생들을 위한 플랫폼

서비스 소개

Hype 한 Voice로 성우가 되고 싶은 사람은 누구나!
내가 올린 작업물들이 곧 내 포트폴리오!
같은 꿈을 키워나가는 사람들과 함께 연습과 피드백도 가능합니다! 😎


프로젝트 진행 기간

2024.01.04 ~ 2024.02.16 (7주) SSAFY 10th 공통 프로젝트

⭐ 기획 배경

게임이나 애니메이션, 대중교통등을 통해 모두 '성우'분들과 간접적으로 접해보셨을 겁니다.
이런 성우가 되려면 어떻게 해야 할까요?
현재 공식적인 성우가 되기 위해서는 방송사들의 공채가 유일한 방법입니다. 하지만 1~2년에 한번 열리며, 심하면 600:1까지 되는
경쟁률로 인해 지망생들은 오랜기간 지망생 생활을 하며 성우가 되기 위해 노력합니다.

HypeVoice는 이를 통해 성우 지망생, 특히 아마추어 성우들을 위한 서비스의 필요성을 느끼고 기획하게 되었습니다!
직접 네이버카페, 오픈 채팅방을 통해 설문을 받아서 저희의 타겟층이 원하는 서비스를 목표로 했습니다.
HypeVoice를 통해 내 목소리를 소개를 좀 더 쉽고 편하게 할 수 있습니다!!

기술 스택


Frontend

  • Visual Studio Code : 1.85.1
  • React : 2.27.0
  • Typescript : 5.2.2
  • Recoil : 0.7.7
  • Tanstack-React-Query : 5.17.19

Backend

  • IntelliJ : 2023.3.4
  • Java : 17.0.9
  • Springboot : 3.2.2
  • Spring Data JPA : 3.2.2
  • Spring Security : 6.2.1
  • QueryDSL : 5.0.0
  • JPQL : 6.4.1
  • Junit5

Infra

  • AWS EC2
  • Nginx
  • Docker

🎤 주요 기능


1. 로그인/회원가입

  • 소셜로그인으로 회원가입 진행 (네이버, 카카오)
  • 꼭 필요한 정보만 받고 타겟층이 주로 사용하는 소셜을 사용한 회원가입으로 접근성을 높였습니다.

2. 나만의 포트폴리오 - 보이스

  • 개발자에게는 GitHub, notion이 있는 것처럼, 성우 지망생들에게는 Hype Voice로 포트폴리오를 제출할 수 있습니다!
  • 메인 화면에서 사람들의 목소리에 대한 작업물이 담긴 포트폴리오(보이스)를 한 곳에 모아볼 수 있습니다.
  • 미디어, 목소리톤, 목소리스타일, 성별, 나이대 등을 선택해 관심있는 보이스만 검색할 수도 있습니다.
  • hypevoice를 찾아온 유저는 새로운 성우를 발굴할 수도 있고, 작업물을 맡길 성우를 구할 수도 있습니다.
  • 좋아요 기능을 통해 관심있는 목소리를 한 번에 모아 볼 수도 있습니다.

3. 작업물

  • 하나의 작업물 당 사진, 녹음본, 대본, 유튜브링크, 설명을 묶어서 등록함으로써, 유저에게 친화적인 등록 과정을 제공합니다.
  • 유저는 대표 작업물 설정을 통해 보여주고 싶은 작업물을 우선순위로 보여줄 수 있습니다.
  • 작업물 하나에 관련 자료를 묶어 보여주면서 보는 사람에게 친화적인 UI 구현

4. 피드백 게시판

  • 영상이나 올리거나 글을 작성해서 피드백을 받거나 자유롭게 소통할 수 있습니다.
  • 피드백 글은 제목, 내용, 작성자, 제목+내용 등으로 검색할 수 있습니다.
  • 각 글에는 댓글을 작성할 수 있습니다.
  • 글 목록은 offset 방식으로 구현되어, 필요한 페이지만 조회해서 넘겨주도록 구현했습니다.

5. 스튜디오

  • webrtc를 사용했으며, openvidu를 활용해 서버를 구축했습니다.
  • 각 방 생성 시 최대 6명까지 들어갈 수 있습니다.
  • 방을 들어가면 화상통화, 녹음, 화상채팅, 화면공유가 가능합니다.
  • 녹음의 경우 녹음을 시작하기 전 자신의 목소리만 녹음할지, 다른 사람의 목소리를 모두 포함해서 녹음할 지 지정할 수 있습니다.

협업 툴

  • Git
  • Jira
  • Notion
  • Figma
  • ERDcloud
  • Discord

📌 협업 환경

  • Gitlab
    • 코드 버전 관리
    • 기능별, 이슈별 브랜치를 생성해서 진행
  • JIRA
    • 매주 월요일 오전 목표량을 정해 스프린트 진행
    • 이슈 별 해야하는 업무를 자세히 작성하고, Story Point와 Epic을 설정하여 작업
  • 데일리 스크럼
    • 매주 오전 데일리 스크럼을 진행하여 서로 간의 진행 상황 공유 및 그날 진행할 업무 브리핑
    • 매일 소통하면서 새로 생기는 이슈에 빠른 대응 가능해짐
  • Notion
    • 회고록 및 회의록이 있을 때마다 매번 기록하여 보관
    • 참고할 기술, 자료 확보 시 자료 공유 페이지에 올려서 모두가 볼 수 있도록 공유
    • 컨벤션 정리 (git, gerrit 등)
    • 문서 정리 (요구사항 명세서, ERD 명세서, API 명세서)
    • develop에 merge되는 브랜치 정리해서 공유
    • 백엔드, 프론트엔드 각각 페이지를 구성해서 실행 과정 정리, secret.yml 파일 등 공유
  • Gerrit
    • 각 브랜치에 리뷰오픈으로 push하여 리뷰에서 통과못하면 merge 못하도록 방지
    • dto에 필요한 추가 변수, 테스트코드 오류, css 깨짐, typescript 오류 부분 등 확인하며 코드 리뷰 진행
    • 코드 리뷰가 모두 완료된 브랜치가 생기면 프론트엔드,백엔드 각 지정한 1명이 develop 브랜치에 merge 진행

프로젝트 산출물



👨‍💻 팀 구성


이름 역할
윤선경(팀장) - BackEnd
- 전역예외 처리 및 테스트 코드 틀 구성 및 작성
- Spring security, JWT, JPA를 이용한 소셜로그인, 회원가입 구현 (인증, 인가)
- 회원,게시판,댓글, 좋아요 관련 CRUD 구현
- AWS S3를 활용한 파일 업로드 기능 구현 및 보이스, 작업물 파일 관련 코드 작성
- 게시글 검색 시 querydsl 사용으로 가독성 높임 및 offset 방식으로 구현
- 오픈비두 서버 배포 및 react, springboot 배포
- Nginx 프론트, 백엔드 분기 처리 (/, /api)
최재식(부팀장) - BackEnd
- 테스트코드 작성
- Spring JPA를 이용한 보이스(포트폴리오), 작업물, 카테고리 관련 CRUD 구현
- JPQL, native query를 사용한 db 관련 로직 처리 및 페이징 처리
- 녹음물, 스크립트과 같은 파일 관련 api 연동
김가빈 - BackEnd
- openvidu를 통한 WebRTC 기능 구현
- openvidu 기능 테스트
- 백엔드 스튜디오 관리 API 구현(방 만들기/방 찾기/방 나가기/방장 부여)
- 백엔드 스튜디오 녹음 파일 저장 및 삭제 기능 구현
- 백엔드 스튜디오 참가 인원 관리 API 구현
- JPQL, native query를 사용한 db 관련 로직 처리 및 페이징 처리, 관련 테스트 코드 작성
김금환 - 내 보이스 구현
- 좋아요 누른 보이스 구현
- 스크롤 네비게이션 구현
- 마이페이지 구현
- 내 보이스, 마이 페이지 CRUD 구현
- 여러 컴포넌트들 구현
- 화면 그리드 나누기
- 전체적인 CSS 다듬기
안상준 - OpenVidu 화면 구현
- StudioList 관련 기능 구현(방 생성, 방 참가, 방 검색)
- 전반적인 프로젝트 설계 (SPA - Routes 구조, 폴더 구조)
- Recoil 및 TanStack-Query 활용 (서버 및 클라이언트 사이트 전역 상태 관리, 타입스크립트 관련 설계)
- 작업물 생성, 수정, 삭제 관련 기능 및 화면 구현
김상민 - FrontEnd
- Community FeedBack 게시판 기능 구현
- (React-Quill을 이용한 글 작성 및 삭제, 댓글 작성 및 삭제, 음성 녹음 후 업로드 기능 등)
- WebRTC Openvidu를 이용한 Studio 기능의 기초적인 구현
- 웹페이지 내의 CSS 디자인 구현

아키텍처


ERD


🎤 HypeVoice 실행 화면


  • 회원가입 및 로그인 / 로그아웃
    • 소셜로그인 (네이버, 카카오)

      kakao naver

  • 메인 화면
    • 보이스 목록, (카테고리) 검색, 조회

      보이스_검색

    • 보이스 좋아요 기능 (좋아요 리스트 추가 및 이동)

      좋아요_기능

  • 내 보이스
    • 내 보이스 작업물 등록

      작업물_등록

    • 대표 작업물 등록, 작업물 상세 화면

      대표_작업물_등록__조회

  • 피드백 게시판
    • 게시글 목록, 페이지

      게시글_목록

    • 게시글 검색

      게시글_검색

    • 게시글 등록 (글 및 유투브 링크 적용)

      게시물_등록

    • 보이스 리플

      보이스_리플

  • 스튜디오
    • 방 생성

    • 방 참여 및 화면 공유

      방_참여_및_화면_공유

    • 채팅

      채팅

    • 녹음(자기 것, 다른사람 것) 녹음 및 다운 기능

  • 마이페이지
    • 마이페이지 프로필 이미지, 닉네임 수정

      마이_페이지_수정

    • 회원 탈퇴

      회원_탈퇴