All Projects → nesterapp → React Native Streetview

nesterapp / React Native Streetview

Licence: mit
React Native Google's Panorama/StreetView component for iOS and Android.

Programming Languages

java
68154 projects - #9 most used programming language

Projects that are alternatives of or similar to React Native Streetview

Gmscore
Free implementation of Play Services
Stars: ✭ 4,356 (+5413.92%)
Mutual labels:  google, mobile, maps
React Native Header View
Fully customizable Header View with multiple design options for React Native.
Stars: ✭ 221 (+179.75%)
Mutual labels:  google, mobile
Google Maps Services Js
Node.js client library for Google Maps API Web Services
Stars: ✭ 2,432 (+2978.48%)
Mutual labels:  google, maps
Open Source Xamarin Apps
📱 Collaborative List of Open Source Xamarin Apps
Stars: ✭ 318 (+302.53%)
Mutual labels:  google, mobile
Laravel Amp
Package that helps you set up AMP (Accelerated Mobile Pages) using Laravel
Stars: ✭ 106 (+34.18%)
Mutual labels:  google, mobile
Placepicker
Free Android Map Place Picker alternative using Geocoder instead of Google APIs
Stars: ✭ 126 (+59.49%)
Mutual labels:  google, maps
Mappa
A canvas wrapper for Maps 🗺 🌍
Stars: ✭ 290 (+267.09%)
Mutual labels:  google, maps
google-streetview-images
Pull google streetview panoramic images along a route.
Stars: ✭ 45 (-43.04%)
Mutual labels:  maps, panorama
Mobly
E2E test framework for tests with complex environment requirements.
Stars: ✭ 424 (+436.71%)
Mutual labels:  google, mobile
Google Map React
Google map library for react that allows rendering components as markers 🎉
Stars: ✭ 5,529 (+6898.73%)
Mutual labels:  google, maps
Yii2 Google Maps Library
Google Maps API library for Yii2
Stars: ✭ 104 (+31.65%)
Mutual labels:  google, maps
Sketch Map Generator
Sketch plugin to fill a shape with a map generated from a given location using Google Maps and Mapbox
Stars: ✭ 824 (+943.04%)
Mutual labels:  google, maps
Ampify
Convert your HTML to Google AMP (Accelerated Mobile Pages)
Stars: ✭ 104 (+31.65%)
Mutual labels:  google, mobile
Magicalexoplayer
The Easiest Way To Play/Stream Video And Audio Using Google ExoPlayer In Your Android Application
Stars: ✭ 171 (+116.46%)
Mutual labels:  google, mobile
Vehicle In Motion
This is a basic implementation of location listener using Google Maps Api
Stars: ✭ 339 (+329.11%)
Mutual labels:  google, maps
Leku
🌍 Map location picker component for Android. Based on Google Maps. An alternative to Google Place Picker.
Stars: ✭ 612 (+674.68%)
Mutual labels:  google, maps
Caranimation
A sample project about car animation in a route
Stars: ✭ 55 (-30.38%)
Mutual labels:  google, maps
Deep merge
Deep (recursive) merge for maps, keywords and others in Elixir
Stars: ✭ 75 (-5.06%)
Mutual labels:  maps
Google cursor
🍭 Cursor theme inspired on Google
Stars: ✭ 78 (-1.27%)
Mutual labels:  google
Drawer Menu Swift
Drawer menu implementation in Swift 4
Stars: ✭ 74 (-6.33%)
Mutual labels:  mobile

react-native-streetview

React Native Google's Panorama/StreetView component for iOS and Android.

  

Installation

yarn add react-native-streetview

Link the native dependencies:

react-native link react-native-streetview

iOS

  1. Install GoogleMaps SDK for iOS using CocoaPods: https://developers.google.com/maps/documentation/ios-sdk/start

  2. Add your API key to AppDelegate:

    Go to https://console.developers.google.com/apis/credentials to check your credentials.

    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
    {
    	[GMSServices provideAPIKey:@"YOUR-API-KEY-HERE"];
    

Android

  1. Install Google Play services using SDK Manager in Android Studio

  2. Add your API key to Manifest file (android\app\src\main\AndroidManifest.xml):

    Go to https://console.developers.google.com/apis/credentials to check your credentials.

    <application>
      <!-- You will only need to add this meta-data tag, but make sure it's a child of application -->
      <meta-data
        android:name="com.google.android.geo.API_KEY"
        android:value="YOUR-API-KEY-HERE"/>
    </application>
    

This installation should work in physical devices and iOS Simulator. For Genymotion, be sure to check Android installation about Google Play Services

Usage

Import

import StreetView from 'react-native-streetview';

Add StreetView component

<View style={styles.container}>
  <StreetView
    style={styles.streetView}
    allGesturesEnabled={true}
    coordinate={{
      'latitude': -33.852,
      'longitude': 151.211
    }}
    pov={{
	tilt:parseFloat(0),
	bearing:parseFloat(0),
	zoom:parseInt(1)
    }}
  />
</View>

Use position absolute for layout

const styles = StyleSheet.create({
  container: {
    flex: 1
  },
  streetView: {
    position: 'absolute',
    top: 0,
    left: 0,
    right: 0,
    bottom: 0,
  },
});

Notice: if you are using react-navigation. There is a known bug where a black window appears upon dismissal of StreetView's container screen - if it was deployed on full screen. A workaround solution is to bound StreetView with some margins. See issue 12

Properties

Prop Type Default Description
allGesturesEnabled bool true Enables user interaction (orientation, zoom, navigation)
coordinate shape null Request panorama near the coordinate
radius number 50 Specify a search radius, in meters, around the coordinate

Example

The 'example' folder contains a fully working example for iOS and Android.
To run the example on iOS do the following:

$ cd example
$ yarn
$ cd ios
$ pod install

Edit AppDelegate.m to add your API key: [GMSServices provideAPIKey:@"YOUR-API-KEY-HERE"];

$ react-native run-ios

To run the example on Android do the following:

$ cd example
$ yarn

Edit AndroidManifest.xml to add your API key: android:value="YOUR-API-KEY-HERE"/>

$ react-native run-android

Roadmap and help?

This component was built to have Street View ability in our Home Renting app, Nester. There is much to go forward, with camera and heading setup, markers, etc. We will gradually add those in the next releases. Feel free to fork and submit PR's. We'll really appriciate any effort, especially on Android ;(

Contact

Amit Palomo [email protected]
Rafael Bodill [email protected]

License

 Copyright (c) 2018 Nester.co.il

 Licensed under the The MIT License (MIT) (the "License");
 you may not use this file except in compliance with the License.
 You may obtain a copy of the License at

    https://raw.githubusercontent.com/nesterapp/react-native-streetview/master/LICENSE

 Unless required by applicable law or agreed to in writing, software
 distributed under the License is distributed on an "AS IS" BASIS,
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 See the License for the specific language governing permissions and
 limitations under the License.
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].