Artify is an innovative mobile application that allows you to explore the world of art in a completely new way. With the advanced technology of Gemini SDK, Artify turns your device into a virtual art gallery, letting you interact with artworks, discover details, history, and context about each piece in real-timeโjust by capturing an image.
Whether you're at a museum ๐๏ธ, visiting an art gallery ๐จ, or simply exploring at home ๐ , Artify offers instant access to detailed information about the artworks you encounter, turning art discovery into an interactive and educational experience.
This app, Artify, includes images and resources designed by Freepik. We would like to thank Freepik for their incredible design resources. The images used in the app are provided with attribution, as required by Freepik's licensing terms. For more information on Freepik's resources, visit www.freepik.com.
Slides are built using the template from Previewed. I extend my gratitude to them for their remarkable work and contribution.
- AI-Powered Visual Exploration ๐ค๐ท: Use Gemini SDK to recognize artworks, sculptures, and other artistic elements through your camera and obtain instant, accurate information.
- Natural Language Interaction ๐ฌ: Ask questions in conversational language and receive detailed, natural responses.
- Speech-to-Text and Text-to-Speech Integration ๐ฃ๏ธ๐: Use your voice to ask questions via Speech-to-Text and listen to the answers through Text-to-Speech, making the interaction even smoother.
- Organized Conversations with Artify ๐๏ธ๐ฌ: Each interaction with an artwork creates an "Art Conversation" where you can ask questions and receive answers about that specific piece.
- Dynamic Learning ๐๐: Turn everyday encounters into learning opportunities, discovering historical facts, technical details, and the context of the artworks you find.
- Enhanced User Experience ๐ฅ๏ธโจ: Built with Jetpack Compose, the app offers a modern UI with fluid animations and intuitive navigation.
- Firestore ๐ฅ๐: Used to store "Art Conversations"โtopics of conversation derived from images taken by the user. Each conversation is linked to a specific artwork and its details.
- Firestorage ๐๏ธ๐ธ: Stores the images captured by the user, which are analyzed by Gemini SDK to provide insightful answers about the artworks or scenes in the photos.
- Gemini SDK ๐๐ค: The AI engine that powers image analysis and natural language understanding, providing detailed answers to user queries based on the images and topics.
- Speech-to-Text and Text-to-Speech ๐ฃ๏ธ๐๐: Allows users to interact with Artify using their voice, asking questions verbally and listening to answers, improving accessibility and convenience.
- Art Conversations List ๐: View all your art conversationsโyour ongoing topics of conversation. Each conversation corresponds to a captured artwork and its related questions and answers.
- Search Functionality ๐: Easily search through your art conversations to find specific topics or answers.
- Delete Functionality ๐๏ธ: Manage your art conversations by deleting those you no longer need.
- Detailed View ๐๏ธ: Access the details of each art conversation, where you can continue the conversation by asking more questions and receiving answers.
- Optimized Performance โก: Using coroutines ensures smooth, lag-free interactions.
- Intuitive Navigation ๐งญ: The UI, built with Jetpack Compose, provides a modern, fluid experience that adapts to user input, making the app feel natural and easy to use.
- Dynamic Responses ๐ฏ: The combination of Gemini SDK and MVI architecture delivers precise, dynamic answers that evolve with user input, creating a responsive and personalized experience.
Artify is built on Clean Architecture principles, ensuring the application is scalable, maintainable, and testable. This architecture promotes clear separation of concerns, with well-defined layers for data, domain, and presentation, resulting in a robust codebase that integrates seamlessly with the Gemini SDK.
By using Model-View-Intent (MVI) as the UI architectural pattern, Artify provides a reactive and unidirectional data flow, enhancing the overall user experience and maintaining the app's consistency and extensibility.
- Domain-Centric Design ๐งฉ: Business logic is encapsulated in the domain layer, which interacts with data sources (e.g., repositories) and manages the flow of information to and from the UI.
- Seamless Integration with Gemini SDK ๐ค๐: The Clean Architecture approach ensures smooth integration with the Gemini SDK, optimizing performance in image recognition and natural language processing tasks.
- Kotlin ๐ป: The primary programming language for Android development.
- Jetpack Compose ๐๏ธ: A modern, declarative UI toolkit that allows for flexible and scalable UI design.
- Gemini SDK ๐๐ค: The core of the app's AI capabilities, powering image recognition and natural language understanding.
- Firestore ๐ฅ: Manages the storage of art conversations, providing a structured and scalable way to handle conversation topics.
- Firestorage ๐ธ: Stores images analyzed by Gemini to generate detailed responses.
- Coroutines โฑ๏ธ: Manages asynchronous tasks to ensure smooth, seamless interactions.
- Hilt/Dagger ๐ ๏ธ: Dependency injection frameworks that provide clear module separation and scalability.
- Retrofit ๐: Manages network communication with external APIs.
- Coil ๐จ: Image loading library that integrates seamlessly with Jetpack Compose for high-performance image handling.
๐ซ Brownie: Jetpack Compose UI Library ๐
Brownie is a Jetpack Compose library that provides a set of pre-defined components to accelerate Android UI development. It helps developers apply best practices in screen state management and utilize the most effective design patterns.
- Pre-defined Components: Brownie offers a variety of ready-to-use components, such as buttons, lists, and cards, to facilitate attractive and consistent UI creation.
- State Management: Facilitates screen state management by implementing patterns like MVI or MVVM.
- Customization: Brownie components are highly customizable and easily adapt to any app's visual style.
- Jetpack Compose Compatibility: Fully integrated with Jetpack Compose, ensuring optimal performance and smooth development.
Brownie encourages using the MVI architecture pattern for effective screen state management. In this pattern:
- Model: Represents the UI state. Brownie provides a
BrownieViewModel
class that handles the UI state. - View: Renders the UI based on the state provided by the ViewModel. Brownie components are seamlessly integrated with Compose for declarative UI.
- Intent: Represents user actions or events that trigger state changes.
For more information, visit Brownie UI Library on GitHub and give it a โญ to show your support!
Here are some screenshots to showcase the app's design and features.
Contributions to Artify are highly encouraged! If you're interested in adding new features, resolving bugs, or enhancing the project's functionality, please feel free to submit pull requests.
Artify is developed and maintained by Sergio Sรกnchez Sรกnchez (Dream Software). Special thanks to the open-source community and the contributors who have made this project possible. If you have any questions, feedback, or suggestions, feel free to reach out at dreamsoftware92@gmail.com.
-
Special thanks to technophilist for the Perceive app, which served as a source of inspiration for this project. Visit Perceive.
-
We express our deep appreciation to Freepik for generously providing the resources used in this project.
-
Icons and images takes from Freepik from www.flaticon.es'
-
Template mockup from https://previewed.app/template/AFC0B4CB
This project is licensed under the MIT License, an open-source software license that allows developers to freely use, copy, modify, and distribute the software. ๐ ๏ธ This includes use in both personal and commercial projects, with the only requirement being that the original copyright notice is retained. ๐
Please note the following limitations:
- The software is provided "as is", without any warranties, express or implied. ๐ซ๐ก๏ธ
- If you distribute the software, whether in original or modified form, you must include the original copyright notice and license. ๐
- The license allows for commercial use, but you cannot claim ownership over the software itself. ๐ท๏ธ
The goal of this license is to maximize freedom for developers while maintaining recognition for the original creators.
MIT License
Copyright (c) 2025 Dream software - Sergio Sรกnchez
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.