Skip to content

bermani/Flixster

Repository files navigation

Project 2 - Flixster

Flixster shows the latest movies currently playing in theaters. The app utilizes the Movie Database API to display images and basic information about these movies to the user, as well as to allow the user to vote on movies.

Time spent: 20 hours spent in total

User Stories

The following required functionality is completed:

  • User can scroll through current movies from the Movie Database API
  • Display a nice default placeholder graphic for each image during loading
  • For each movie displayed, user can see the following details:
  • Title, Poster Image, Overview (Portrait mode)
  • Title, Backdrop Image, Overview (Landscape mode)
  • Allow user to view details of the movie including ratings and popularity within a separate activity

The following stretch features are implemented:

  • Improved the user interface by experimenting with styling and coloring.
  • Apply rounded corners for the poster or background images using Glide transformations
  • Apply the popular View Binding annotation library to reduce boilerplate code.
  • Allow video trailers to be played in full-screen using the YouTubePlayerView from the details screen.

The following additional features are implemented:

  • Implement multiple tabs to allow users to not only see Now Playing movies, but Top Rated and Upcoming movies as well.
  • Add the movie's release date and genres to the details view
  • Allow the user to vote on movies through the details view

Video Walkthrough

Here's a walkthrough of implemented user stories:

Video Walkthrough

GIF created with Kap.

Notes

The biggest challenge I encountered was the difficulty in learning the large volume of information required to complete the project. I had to learn about Android features like View Binding, ScrollView, TabLayout, and advanced styling techniques. I had to consult the documentation on the movie API to implement new routes and properly send GET and POST requests with the CodePath HTTP library. I had to learn how to properly organize and debug my project to improve code quality and reduce bugs. It was challenging to get through all of the content and learn the material in order to implement all of the features I did, but I'm very proud of what I managed to accomplish. I also ran into some minor configuration and network issues, but resolved those with relative ease.

Open-source libraries used

  • CPAsyncHttpClient - Simple asynchronous HTTP requests with JSON parsing
  • Glide - Image loading and caching library for Android
  • Parceler - Library to make passing objects between Contexts easy

License

Copyright [yyyy] [name of copyright owner]

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.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages