LoginSignup
4
0

More than 1 year has passed since last update.

シチュエーション別に選べる!NetflixとHuluの【ドラマ】【アニメ】ランダムチョイスアプリを作ってみた!

Last updated at Posted at 2023-04-09

サービス名

サブスクルーレット

サービス概要

・Netflix、Huluのどちらかを選択、更にシチュエーション(テンション上げたい、チルしたい、ハラハラしたい)を選択し、その中からランダムでドラマを選んでくれるアプリ。

ターゲット

・Netflix、Huluなどのサブスクを使用している人で、次に観るものが決まっていない、または、決めるのが面倒な人向けのサービスとなっております。

なぜこのサービスを作ったのか?

今回このサービスを作ったのは、私は、仕事終わりや休日にサブスクリプションサービスを利用してドラマやアニメをよく観ます。しかし、次に何を観るかを選ぶのは面倒で、選択肢が多すぎます。また、私がドラマやアニメを選ぶ基準は、基本的にポスター画像が「いい感じ」かどうかです。そこで、ランダムにドラマやアニメが表示され、ポスター画像やタイトル、概要で「いい感じ」のものが出てきたら、そのまま視聴することができるサービスを作成しました。選択肢から迷わず、気楽にサブスクリプションを楽しめるようになりました。

サービス詳細

ランダムで、ドラマ、TV番組を表示

①ユーザーは、NetflixかHuluか選択する。
スクリーンショット 2022-10-27 21 26 49

②次に、シチュエーションを選択する。『テンション上げたい』、『チルした』、『ハラハラしたい』。
スクリーンショット 2022-10-29 16 52 02

③シチュエーションを選択したら、ランダムでそのシチュエーションに合ったドラマが出てくる。
スクリーンショット 2022-10-27 21 34 31

④ユーザー登録者は、気になる機能を使ってランダムで出てきたドラマを保存することが出来る。
スクリーンショット 2022-10-27 21 34 43

※ゲストユーザーは気になるボタンは表示されません。
スクリーンショット 2022-10-28 0 37 00

ユーザー画面から気になるを表示

ポートフォリオ

コメント機能

スクリーンショット 2023-04-04 2 48 33

機能一覧

・ユーザー登録機能

・ランダムでドラマを表示する機能

・気になる機能(ランダムで選択された映画の画面に『気になる』ボタンがあ りユーザー画面で『気になる一覧』で確認できるようにできる)

・コメント機能

ER図

スクリーンショット 2023-04-04 3 11 28

力を入れたポイント

The Movie Database (TMDb)から取得する情報を常に最新にしておきたかったので、【動画付き】外部APIに依存するRailsアプリケーションの設計とテストの書き方の記事を参考に、DBにデータが保存されているのではなく、外部APIから取得したデータをあたかもDBから取得したデータのように扱うRailsアプリケーションを作りました。

①ドラマ、アニメをランダムに表示する機能

def all(params = {})
      provider_id = params[:provider_id]
      genre_id = params[:genre_id]
      provider = URI.encode_www_form({with_networks: provider_id})
      genre = URI.encode_www_form({with_genres: genre_id})
      tmdb = URI.parse("https://api.themoviedb.org/3/discover/tv?api_key=#{ENV['API_KEY']}&language=ja-JP&#{provider}&#{genre}")
      response = Net::HTTP.get(tmdb)
      tmdb_list = JSON.parse(response)
      uri = URI.parse("https://api.themoviedb.org/3/discover/tv?api_key=#{ENV['API_KEY']}&language=ja-JP&#{provider}&#{genre}&page=#{rand(tmdb_list['total_pages'])+1}")
      json = Net::HTTP.get(uri)
      data_list = JSON.parse(json)
      movie = data_list["results"]
      movie.map do |data|
        Movie.new(data)
      end
    end

上記のコードは、TMDBという映画データベースのAPIを利用して、指定された条件に基づいてドラマ、アニメを検索し、ランダムに1つのドラマ、アニメを取得するためのメソッドです。

引数としてprovider_idとgenre_idが指定されます。provider_idはプロバイダ(NetflixやHuluなど)のIDを、genre_idはジャンル(ロマンス、ホラーなど)のIDを指定します。それぞれ、URIエンコードされてAPIリクエストのクエリパラメータに含まれます。

まず、provider_idとgenre_idをもとに、指定された条件に合致するドラマ、アニメのリストを取得します。取得されたリストは、ランダムなページ番号を指定して、ランダムに1つのドラマ、アニメを取得するためのURIを作成します。

次に、ランダムに選択されたドラマ、アニメのデータを取得し、そのデータをMovieクラスのインスタンスとして配列に格納して返します。

②「気になる」機能

def like(params = {})
  user_id = params[:user_id]
  likes = Like.where(user_id: user_id).order(created_at: :desc).pluck(:movie_id)
  @likeslist = []
  likes.map do |id|
  uri = URI.parse("https://api.themoviedb.org/3/tv/#{id}?api_key=#{ENV['API_KEY']}&language=ja-JP")
  json = Net::HTTP.get(uri)
  result = JSON.parse(json)
  likeslist = result
  @likeslist += [likeslist]
  end
  list = @likeslist
  list.map do |list|
    Movie.new(list)
  end
end

上記のコードは、指定されたユーザーが「いいね」したドラマ、アニメのリストを取得し、その情報をもとにMovieオブジェクトのリストを生成するためのメソッドです。

引数としてuser_idが指定され、Likeモデルからuser_idが一致するレコードを取得し、作成日時の新しい順にソートされたmovie_idの配列を取得します。

その後、movie_idをもとに、TMDB APIからTVドラマの情報を取得し、それぞれの情報をlikeslistに格納します。最後に、likeslistを@likeslistに追加し、@likeslistの要素数分、Movieオブジェクトを生成してリストに格納し、返します。

③「気になる」の詳細ページ

def like_movies(params = {})
  movie_id = params[:movie_id].to_i
  uri = URI.parse("https://api.themoviedb.org/3/tv/#{movie_id}?api_key=#{ENV['API_KEY']}&language=ja-JP")
  json = Net::HTTP.get(uri)
  result = JSON.parse(json)
  movie = [result]
  movie.map do |data|
    Movie.new(data)
  end
end

上記のコードは、指定されたmovie_idに対応するドラマアニメの情報をTMDB APIから取得し、それをもとにMovieオブジェクトを生成するためのメソッドです。

引数としてmovie_idが指定され、それをもとに、TMDB APIからドラマアニメの情報を取得します。取得したJSONデータをパースし、Movieオブジェクトに変換してリストに格納します。最後に、リストを返します。

4
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
0