saitoxu.io

AboutTwitterGitHub

React NativeでInstagramのクローンを作ってみた

August 20, 2017

React Native で動画ってどう扱うんだろうと思い、 react-native-community/react-native-video を触りだしたんですが、いっそもう少し形にしようと思い Instagram のクローンを作りました(ホーム画面だけ)。

screenshot

機能

とりあえず動画の取り扱いを知りたかったので、 本家 Instagram のホーム画面の一部の機能だけを実装してます。

  • 動画の再生/停止
  • 画像の表示

他の画面は遷移はできますが空のビューを表示しています。

使用した主なライブラリ

主に使用したライブラリは次の 2 つです。

react-native-video

React Native で動画を扱うライブラリです。 React Native コミュニティで開発されており、 動画を扱うならデファクトスタンダードと言ってよいでしょう。

react-native-navigation

ホームページ作成の wix のチームが作っているナビゲーションライブラリです。 React Native のナビゲーションライブラリはreact-community/react-navigationをはじめ けっこう乱立している印象がありますが、 この wix の react-native-navigation は順調にスター数(GitHub)を伸ばしているようです。

自分はこれまで使ったことがなかったので、今回勉強がてら使ってみることにしました。

雑感

作っている最中に思ったことをつらつらと書きます。

react-native-video は使いやすい

Videoコンポーネントだけを提供しているので当然かもしれませんが、 シンプルで使いやすかったです。

ローカルの動画だけでなくリモートの動画もロードして再生できますし、 バッファリングの状態も取得できたりするので細かく制御できそうだなと思いました。

react-native-navigation は斬新

react-native-navigation は React Native 標準のエントリーポイントを書き換える必要があり、 これは新しいなと思いました。

// index.ios.js
import { Navigation } from "react-native-navigation"

import { registerScreens } from "./screens"

registerScreens() // Navigationに画面を登録する

Navigation.startTabBasedApp({
  tabs: [
    {
      label: "One",
      screen: "example.FirstTabScreen", // 各画面に付与されたキーを渡す
      icon: require("../img/one.png"),
      selectedIcon: require("../img/one_selected.png"),
      title: "Screen One",
    },
    {
      label: "Two",
      screen: "example.SecondTabScreen",
      icon: require("../img/two.png"),
      selectedIcon: require("../img/two_selected.png"),
      title: "Screen Two",
    },
  ],
})

// 通常は次のようにRootのコンポーネントをAppRegistryに渡す形になる
// AppRegistry.registerComponent('AwesomeApp', () => AwesomeApp)

ただ上記を見てもらうと分かるように、 使い方自体は分かりやすくドキュメントも整備されているので 初めてでしたがすんなり使えました。

現在次のメジャーバージョンの開発が行われているみたいなので、 期待して待ちたいと思います。

おわりに

以上、Instagram クローンを作ってみての雑感でした。 どちらのライブラリも使いやすかったので、ぜひプロダクトで使ってみたいなと思いました。

Instagram クローンのソースは以下においてますので参考にしてください。

saitoxu/InstaClone


© 2021, Yosuke Saito