Git Product home page Git Product logo

ridesharing-uber-lyft-app's Introduction

Ride-Sharing Uber Lyft Android App

Learn to build a ride-sharing Android Taxi Clone App like Uber, Lyft - Open-Source Project


About me

Hi, I am Amit Shekhar, I have mentored many developers, and their efforts landed them high-paying tech jobs, helped many tech companies in solving their unique problems, and created many open-source libraries being used by top companies. I am passionate about sharing knowledge through open-source, blogs, and videos.

You can connect with me on:

My Personal Blog - amitshekhar.me - High-quality content to learn Android concepts.

We will build and learn the following for the App like Uber and Lyft:

  • Create Rider Android Clone App
  • Fetch and show nearby cabs on Google Map
  • Set Pickup and drop location
  • Book a cab
  • Fetch and show driver current location
  • Show pickup and trip path on Map with Animation
  • Cab Arrival for a pickup like Uber
  • On-going trip UI
  • Trip End
  • Animation like Uber App for Moving Car
  • Just to make it simple. This project uses the basic MVP Architecture for building the Uber and Lyft clone
  • We have simulated the WebSocket API for you

We have simulated the backend environment for you to get the real-work like experience.

Screenshots from this project


Building the project

  • Every feature is easy to follow.
  • Clone the project, the master branch has the latest code.
  • To learn and implement from the beginning, start with a new project.
  • This App uses the Google API Key for Maps, Directions, and Places. Get the API key from the Google Cloud Developer console after enabling the Maps, Directions and Places features for your project. Refer this link. And put that key in the local.properties file in your project: Your local.properties will like below:
sdk.dir=PATH_TO_ANDROID_SDK_ON_YOUR_LOCAL_MACHINE    
apiKey=YOUR_API_KEY
  • Start implementing features:
    • Start with a new project.
    • Setup project with basic MVP Architecture.
    • Implement Permission for fetching current location.
    • Implement feature - nearby cabs.
    • Use WebSocket present in simulator module to fetch the nearby cabs.
    • Implement feature - pickup and drop location.
    • Implement feature - book a cab.
    • Implement feature - Show pickup path on the map with Animation.
    • Implement feature - Show the current driver location during pickup.
    • Implement feature - Cab is arriving and arrived.
    • Implement feature - Car Animation like Uber.
    • Implement feature - Show trip path on the map with Animation.
    • Implement feature - Trip Starts.
    • Implement feature - Show the current driver location during the trip.
    • Implement feature - Trip on-going.
    • Implement feature - Trip Ends.
    • Implement feature - Implement Take Next Ride.

WebSocket API Reference for this project

A WebSocket is a persistent connection between a client and server. WebSockets provide a bidirectional, full-duplex communications channel that operates over HTTP through a single TCP/IP socket connection. At its core, the WebSocket protocol facilitates message passing between a client and server. In our case, we have simulated it for you.

  • In WebSocket, we have three methods:

    • connect(): To connect with the server
    • sendMessage(data: String): To send the data to the server
    • disconnect(): To disconnect from the server
  • In WebSocketListener, we have four callbacks:

    • onConnect(): Called when it is connected with the server
    • onMessage(data: String): Called when an event comes from the server
    • fun onDisconnect(): Called when the client is disconnected from the server
    • fun onError(error: String): Called when the error occurred on the server
  • Client sending event to server using webSocket.sendMessage(data):

    • Request for nearby cabs from server
    {
      "type": "nearByCabs",
      "lat": 28.438147,
      "lng": 77.0994446
    }
    • Request a cab from server
    {
      "type": "requestCab",
      "pickUpLat": 28.4369353,
      "pickUpLng": 77.1125599,
      "dropLat": -25.274398,
      "dropLng": 133.775136
    }
  • The Server sending success event to the client received in onMessage(data: String):

    • NearBy cabs
    {
      "type": "nearByCabs",
      "locations": [
        {
          "lat": 28.439147000000002,
          "lng": 77.0944446
        },
        {
          "lat": 28.433147,
          "lng": 77.0952446
        },
        {
          "lat": 28.440547000000002,
          "lng": 77.1026446
        }
      ]
    }
    • Cab Booked
    {
      "type": "cabBooked"
    }
    • PickUp Path
    {
      "type": "pickUpPath",
      "path": [
        {
          "lat": 28.43578,
          "lng": 77.10198000000001
        },
        {
          "lat": 28.43614,
          "lng": 77.10164
        },
        {
          "lat": 28.436400000000003,
          "lng": 77.10149000000001
        }
      ]
    }
    • Cab Current Location during pickup or trip
    {
      "type": "location",
      "lat": 28.43578,
      "lng": 77.10198000000001
    }
    • Cab is Arriving
    {
      "type": "cabIsArriving"
    }
    • Cab Arrived
    {
      "type": "cabArrived"
    }
    • Trip Start
    {
      "type": "tripStart"
    }
    • Trip Path
    {
      "type": "tripPath",
      "path": [
        {
          "lat": 28.438370000000003,
          "lng": 77.09944
        },
        {
          "lat": 28.438450000000003,
          "lng": 77.1006
        },
        {
          "lat": 28.438480000000002,
          "lng": 77.10095000000001
        }
      ]
    }
    • Trip End
    {
      "type": "tripEnd"
    }
  • The server sending the error event to the client received in onError(error: String):

    • Direction API Failed
    {
      "type": "directionApiFailed",
      "error": "Unable to resolve host \"maps.googleapis.com\": No address associated with hostname"
    }
    • Routes Not Available
    {
      "type": "routesNotAvailable"
    }

Find this project useful ? ❤️

  • Support it by clicking the ⭐ button on the upper right of this page. ✌️

License

   Copyright (C) 2024 Amit Shekhar

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

       http://www.apache.org/licenses/LICENSE-2.0

   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.

ridesharing-uber-lyft-app's People

Contributors

amitshekhariitbhu avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

ridesharing-uber-lyft-app's Issues

[Request] - Add GitHub Actions CI for Build

Hi @amitshekhariitbhu,
It would be nice to have a CI support for this repository which will be triggered on every Push/Pull Request. Also, new usable APK will be generated every time which will help you to review Pull requests too.
I've forked this repository and integrated GitHub Actions CI. If it looks good to you, I'm happy to open PR.

Files need to change:

LMK if it looks good to you. See below pictures.

  • GitHub Actions - Build:
    1

  • Generated Artifact (APK) on trigger:
    2

place and direction api

where do I add place and direction API?
I can't search for places, it pops up and disappears when I type for a place.
I have added map API under local properties. is it in the same file with a different string name?

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.