Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mohamedmagdy2301/weather-app
https://github.com/mohamedmagdy2301/weather-app
Last synced: 1 day ago
JSON representation
- Host: GitHub
- URL: https://github.com/mohamedmagdy2301/weather-app
- Owner: mohamedmagdy2301
- Created: 2024-07-18T00:04:47.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-07-28T03:33:29.000Z (4 months ago)
- Last Synced: 2024-07-28T04:32:09.044Z (4 months ago)
- Language: Dart
- Size: 1.07 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[![Flutter Version](https://img.shields.io/badge/Flutter-v3.0-blue.svg)](https://flutter.dev/)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)A Flutter-based weather application that provides real-time weather updates, forecasts, and detailed weather data using BLoC for state management.
## Features
- **Current Weather**: Displays the current weather conditions for the user's location.
- **Weather Forecast**: Shows temperature forecasts, detailed information on air quality, sun, and moon cycles.
- **Search Functionality**: Allows users to search for weather conditions in other cities.
- **Precipitation Details**: Provides information on weekly precipitation and thunderstorms.
- **Graphical Charts**: Visual representation of weather data through charts for easier understanding.
- **Intuitive UI**: A smooth, gradient-based user interface with a sleek and modern design.## Installation
1. Clone the repository:
```bash
git clone https://github.com/your_username/weather_app.git
```
2. Navigate to the project directory:
```bash
cd weather_app
```
3. Get the required packages:
```bash
flutter pub get
```## Usage
1. Connect a device or start an emulator.
2. Run the app using:
```bash
flutter run
```
3. The app will fetch the user's current location weather or allow the user to search for a city's weather using the search bar.## Project Structure
- **cubit/**: Contains the BLoC implementation for managing the weather data state.
- **widgets/**: Contains reusable widgets for different UI components.
- **screens/**: Contains the main screens like `HomePage` and `SearchPage`.## Main Components
### TodayTap
Displays today's weather details, including:
- Date, temperature, and weather status.
- Hourly temperature list.
- Air quality information.
- Sun and moon cycles.### HomePage
- Uses `BlocBuilder` to manage state and display loading, loaded, or error states.
- Allows navigation to the search page to find weather data for specific cities.### PrecipitationTap
Provides precipitation-related information, such as:
- Weekly precipitation data.
- Thunderstorm details.### ForecastTap
- Displays weather forecasts with visual data using charts.
- Shows weekly weather forecast with temperature variations.## Screenshots
| Splash Screen 1 | Splash Screen 2 | Splash Screen 3 | Splash Screen 4 |
|---|---|---|---|
| ![Screenshot](assets/s1.png) | ![Screenshot](assets/s2.png) | ![Screenshot](assets/s3.png) | ![Screenshot](assets/s4.png) || Today Screen | Today Screen | Forecast Screen | Precipitation Screen | Search Screen |
|---|---|---|---|---|
| ![Screenshot](assets/s12.png) | ![Screenshot](assets/s15.png) | ![Screenshot](assets/s13.png) | ![Screenshot](assets/s14.png) | ![Screenshot](assets/s16.png)|## Dependencies
- **flutter_bloc**: State management using the BLoC pattern.
- **flutter**: Flutter SDK for UI development.## Contributing
Contributions are welcome! Feel free to submit a Pull Request with improvements, bug fixes, or new features.
1. Fork the repository.
2. Create a new branch (`git checkout -b feature/my-feature`).
3. Make your changes and commit (`git commit -am 'Add new feature'`).
4. Push to the branch (`git push origin feature/my-feature`).
5. Create a new Pull Request.## Congratulations
You’ve successfully integrated Chat App into your Flutter app! For more advanced features and customization options.
If you found this guide helpful, don’t forget to ⭐ star this repository on GitHub to show your support!
Thank you for reading!
## Contact
For any questions or inquiries, feel free to reach out:
- **GitHub:** [mohamedmagdy2301](https://github.com/mohamedmagdy2301)
- **Email:** [[email protected]]([email protected])## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.