This media is not supported in your browser
VIEW IN TELEGRAM
Creating a Portfolio app with Flutter
The full video is available on YouTube:
https://youtu.be/aKoxZEvQIgY?si=dBIOhDhyvgXdykdn
The full video is available on YouTube:
https://youtu.be/aKoxZEvQIgY?si=dBIOhDhyvgXdykdn
👍7👏6
This media is not supported in your browser
VIEW IN TELEGRAM
Building a Wheel of Fortune app in Flutter 🎡✨
The training video is available on YouTube:
https://youtu.be/2HGUGjEEPck
The training video is available on YouTube:
https://youtu.be/2HGUGjEEPck
👍5🔥2
This media is not supported in your browser
VIEW IN TELEGRAM
Implementation of Flip animation in Flutter
The training video is available on YouTube:
https://youtu.be/IiaUgN14C9U
The training video is available on YouTube:
https://youtu.be/IiaUgN14C9U
🔥10👍1
This media is not supported in your browser
VIEW IN TELEGRAM
Building an Onboarding Screen for a Car Rental App using Flutter
The training video is available on YouTube:
https://youtu.be/MnCjAqQFtoE?si=k33zFyYzJNxhMHJP
The training video is available on YouTube:
https://youtu.be/MnCjAqQFtoE?si=k33zFyYzJNxhMHJP
🔥6👏2
If you're in china or in a country under an embargo and need to use a Chinese Pub repository (or any custom package repository) in Flutter, you can configure your Flutter environment to use a mirror repository hosted in China. This is useful if the official Pub repository (
Here’s how you can set it up:
1. Identify a Reliable Chinese Pub Mirror
Some popular Chinese Pub mirrors include:
- https://pub.flutter-io.cn (official Flutter China mirror)
- https://pub.dev.ixigua.com (by ByteDance)
These mirrors host the same packages as the official Pub repository but are hosted on servers in China.
2. Configure Flutter to Use the Chinese Pub Mirror
You need to set the
Option 1: Set Environment Variables
- On macOS/Linux:
1. Open your terminal.
2. Edit your shell configuration file (e.g.,
3. Save the file and reload the shell:
- On Windows:
1. Open Command Prompt or PowerShell.
2. Run the following command to set the environment variable:
3. Restart your terminal or IDE for the changes to take effect.
Option 2: Use a
You can also specify the custom repository directly when running Flutter commands:
Update Your
- Your
- Example
---
4.Run
- After configuring the custom repository, run:
- Flutter will fetch the packages from the Chinese mirror repository.
Verify the Configuration
- Check the logs when running
Troubleshooting
- If you encounter issues:
- Ensure the
- Verify that the mirror repository is accessible from your network.
- Make sure your Flutter SDK is up to date.
Switch Back to the Default Pub Repository
If you want to switch back to the default Pub repository, unset the
Additional Notes for Embargoed Countries
- If you are in a country under an embargo, you may also need to use a VPN or proxy to access certain resources or repositories.
- Ensure that using a Chinese mirror complies with your local laws and regulations.
By following these steps, you can configure Flutter to use a Chinese Pub repository, allowing you to access Flutter packages even if the official Pub repository is inaccessible due to embargo restrictions.
https://pub.dev) is inaccessible due to embargo restrictions.Here’s how you can set it up:
1. Identify a Reliable Chinese Pub Mirror
Some popular Chinese Pub mirrors include:
- https://pub.flutter-io.cn (official Flutter China mirror)
- https://pub.dev.ixigua.com (by ByteDance)
These mirrors host the same packages as the official Pub repository but are hosted on servers in China.
2. Configure Flutter to Use the Chinese Pub Mirror
You need to set the
PUB_HOSTED_URL environment variable to point to the Chinese mirror.Option 1: Set Environment Variables
- On macOS/Linux:
1. Open your terminal.
2. Edit your shell configuration file (e.g.,
.bashrc, .zshrc, or .bash_profile):export PUB_HOSTED_URL=https://pub.flutter-io.cn
3. Save the file and reload the shell:
source ~/.bashrc # or source ~/.zshrc
- On Windows:
1. Open Command Prompt or PowerShell.
2. Run the following command to set the environment variable:
setx PUB_HOSTED_URL "https://pub.flutter-io.cn"
3. Restart your terminal or IDE for the changes to take effect.
Option 2: Use a
flutter CommandYou can also specify the custom repository directly when running Flutter commands:
flutter pub get --hosted-url=https://pub.flutter-io.cn
Update Your
pubspec.yaml- Your
pubspec.yaml file does not need any special changes. Flutter will automatically use the repository specified in the PUB_HOSTED_URL environment variable.- Example
pubspec.yaml:dependencies:
flutter:
sdk: flutter
http: ^0.13.3
---
4.Run
flutter pub get- After configuring the custom repository, run:
flutter pub get
- Flutter will fetch the packages from the Chinese mirror repository.
Verify the Configuration
- Check the logs when running
flutter pub get. It should show the custom repository URL in the output, confirming that Flutter is using the Chinese mirror.Troubleshooting
- If you encounter issues:
- Ensure the
PUB_HOSTED_URL environment variable is correctly set.- Verify that the mirror repository is accessible from your network.
- Make sure your Flutter SDK is up to date.
Switch Back to the Default Pub Repository
If you want to switch back to the default Pub repository, unset the
PUB_HOSTED_URL environment variable or set it to the official URL:export PUB_HOSTED_URL=https://pub.dev
Additional Notes for Embargoed Countries
- If you are in a country under an embargo, you may also need to use a VPN or proxy to access certain resources or repositories.
- Ensure that using a Chinese mirror complies with your local laws and regulations.
By following these steps, you can configure Flutter to use a Chinese Pub repository, allowing you to access Flutter packages even if the official Pub repository is inaccessible due to embargo restrictions.
Dart packages
The official repository for Dart and Flutter packages.
Pub is the package manager for the Dart programming language, containing reusable libraries & packages for Flutter and general Dart programs.
🔥7🙏1
Boost Your Flutter Development with Fake Data Using the Faker Package!
Hey Flutter Enthusiasts! 👋
Ever found yourself in a situation where you needed dummy data to test your app, but creating it manually felt like a waste of time? Worry no more! The Faker package is here to save the day! 🦸♂️
What is the Faker Package?
The Faker package is a Dart library that generates fake data for you. Whether you need names, addresses, phone numbers, or even lorem ipsum text, Faker has got you covered. It’s perfect for prototyping, testing, or even creating mockups for your Flutter apps.
Why Use Fake Data?
- Speed up development: No more wasting time creating dummy data manually.
- Realistic testing: Generate data that looks real, making your tests more accurate.
- Prototyping: Quickly build and showcase your app with realistic-looking data.
How to Use Faker in Flutter
1. Add the Dependency:
First, add the Faker package to your
Don’t forget to run
2. Import the Package:
Import the Faker package in your Dart file:
3. Generate Fake Data:
Now, you can start generating fake data! Here are some examples:
4. Use It in Your App:
You can use this fake data in your widgets, models, or anywhere you need it. For example:
Example: Generating a List of Fake Users
Here’s a quick example of how you can generate a list of fake users:
Wrap-Up
The Faker package is a must-have tool for any Flutter developer.
It saves time, makes testing easier, and helps you focus on what really matters—building awesome apps!
#Flutter #FakerPackage #FakeData #FlutterDev #MobileDevelopment #Prototyping #Testing
Join my Telegram channel for more Flutter tips, tricks, and updates!
👉 @alesdevstudio 👈
Keep Fluttering! 🦋
Hey Flutter Enthusiasts! 👋
Ever found yourself in a situation where you needed dummy data to test your app, but creating it manually felt like a waste of time? Worry no more! The Faker package is here to save the day! 🦸♂️
What is the Faker Package?
The Faker package is a Dart library that generates fake data for you. Whether you need names, addresses, phone numbers, or even lorem ipsum text, Faker has got you covered. It’s perfect for prototyping, testing, or even creating mockups for your Flutter apps.
Why Use Fake Data?
- Speed up development: No more wasting time creating dummy data manually.
- Realistic testing: Generate data that looks real, making your tests more accurate.
- Prototyping: Quickly build and showcase your app with realistic-looking data.
How to Use Faker in Flutter
1. Add the Dependency:
First, add the Faker package to your
pubspec.yaml file:dependencies:
faker: ^2.0.0
Don’t forget to run
flutter pub get to install the package.2. Import the Package:
Import the Faker package in your Dart file:
import 'package:faker/faker.dart';
3. Generate Fake Data:
Now, you can start generating fake data! Here are some examples:
final faker = Faker();
// Generate a fake name
String name = faker.person.name();
// Generate a fake email
String email = faker.internet.email();
// Generate a fake address
String address = faker.address.streetAddress();
// Generate a random lorem ipsum sentence
String lorem = faker.lorem.sentence();
// Generate a fake phone number
String phoneNumber = faker.phoneNumber.us();
4. Use It in Your App:
You can use this fake data in your widgets, models, or anywhere you need it. For example:
ListTile(
noscript: Text(name),
subnoscript: Text(email),
);
Example: Generating a List of Fake Users
Here’s a quick example of how you can generate a list of fake users:
List<Map<String, String>> generateFakeUsers(int count) {
final faker = Faker();
return List.generate(count, (index) {
return {
'name': faker.person.name(),
'email': faker.internet.email(),
'phone': faker.phoneNumber.us(),
};
});
}Wrap-Up
The Faker package is a must-have tool for any Flutter developer.
It saves time, makes testing easier, and helps you focus on what really matters—building awesome apps!
#Flutter #FakerPackage #FakeData #FlutterDev #MobileDevelopment #Prototyping #Testing
Join my Telegram channel for more Flutter tips, tricks, and updates!
👉 @alesdevstudio 👈
Keep Fluttering! 🦋
🔥4❤3❤🔥2🥱1
This media is not supported in your browser
VIEW IN TELEGRAM
Implementation of Mobile OTP Authentication for a Car Rental app using Flutter
The training video is available on YouTube: https://youtu.be/DeR_fsx0JuI?si=TZUKNeY6mI257Uan
The training video is available on YouTube: https://youtu.be/DeR_fsx0JuI?si=TZUKNeY6mI257Uan
🔥5❤2
Boost Your Flutter Development with
Tired of manually managing assets and dealing with runtime errors?
Say hello to flutter_gen a game-changing package that automates resource management and brings type safety to your Flutter projects!
The
Instead of manually writing paths or configurations for assets,
Benefits of using
1. Asset Management: Automatically generates Dart classes for accessing assets (images, icons, etc.) with type-safe references.
2. Font Management: Simplifies the process of using custom fonts by generating font family classes.
3. Color Management: Generates color constants from your project's color definitions.
4. Localization Support: Can integrate with localization tools to generate type-safe access to localized strings.
5. Customizable: Allows customization of the generated code to fit your project's needs.
Example Usage:
1. Add
2. Configure the
3. Run the code generator using the command
4. Use the generated classes to access assets, fonts, or colors in your app.
Example:
By using
Package URL:
You can find the
flutter_gen!Tired of manually managing assets and dealing with runtime errors?
Say hello to flutter_gen a game-changing package that automates resource management and brings type safety to your Flutter projects!
The
flutter_gen package is a code generation tool for Flutter that helps automate the process of managing assets, fonts, colors, and other resources in your Flutter project. Instead of manually writing paths or configurations for assets,
flutter_gen generates type-safe, easy-to-use Dart code, reducing the risk of errors and improving developer productivity.Benefits of using
flutter_gen package:1. Asset Management: Automatically generates Dart classes for accessing assets (images, icons, etc.) with type-safe references.
2. Font Management: Simplifies the process of using custom fonts by generating font family classes.
3. Color Management: Generates color constants from your project's color definitions.
4. Localization Support: Can integrate with localization tools to generate type-safe access to localized strings.
5. Customizable: Allows customization of the generated code to fit your project's needs.
Example Usage:
1. Add
flutter_gen to your pubspec.yaml under dev_dependencies.2. Configure the
flutter_gen settings in pubspec.yaml to specify asset paths, fonts, etc.3. Run the code generator using the command
flutter pub run build_runner build.4. Use the generated classes to access assets, fonts, or colors in your app.
Example:
// Accessing an image asset
Image.asset(Assets.images.logo.path);
// Using a custom font
Text(
'Hello, Flutter!',
style: TextStyle(fontFamily: FontFamily.roboto),
);
By using
flutter_gen, you can streamline resource management in your Flutter projects, making your code cleaner and more maintainable.Package URL:
You can find the
flutter_gen package on https://pub.dev/packages/flutter_gen❤4👍4🔥2👎1
Flutter Keys Explained: Unlocking Widget Identity & State!
Hey Flutter Devs!
Ever wondered how Flutter keeps track of widgets when the UI rebuilds?
The secret lies in Keys! Let’s dive into the world of Flutter keys and learn how they help manage widget identity and state. 🗝️
What Are Keys?
Keys are unique identifiers for widgets in the widget tree. They help Flutter determine which widgets have changed, been added, or been removed during rebuilds. Without keys, Flutter might lose track of the widget state, leading to unexpected behavior.
Types of keys:
1️⃣ ValueKey
Use a value (like a string or number) to identify a widget.
2️⃣ UniqueKey
Generates a unique key every time it’s created.
3️⃣ GlobalKey
Access a widget’s state globally.
4️⃣ PageStorageKey
Save and restore state (e.g., scroll position).
Example: Using Keys in a List
When reordering items in a list, keys help Flutter know which widgets moved:
Example: GlobalKey in a Form
Use a
When to Use Keys:
✅ Preserving State: Keep widget state intact during rebuilds.
✅ Reordering Widgets: Ensure Flutter correctly identifies moved widgets in a list.
✅ Accessing State: Use GlobalKey to access widget state from outside its subtree.
Why Are Keys Important?
Keys ensure Flutter can efficiently update the UI and maintain widget state. They’re essential for building dynamic, stateful, and performant apps.
Hey Flutter Devs!
Ever wondered how Flutter keeps track of widgets when the UI rebuilds?
The secret lies in Keys! Let’s dive into the world of Flutter keys and learn how they help manage widget identity and state. 🗝️
What Are Keys?
Keys are unique identifiers for widgets in the widget tree. They help Flutter determine which widgets have changed, been added, or been removed during rebuilds. Without keys, Flutter might lose track of the widget state, leading to unexpected behavior.
Types of keys:
1️⃣ ValueKey
Use a value (like a string or number) to identify a widget.
ValueKey<String>('item1')2️⃣ UniqueKey
Generates a unique key every time it’s created.
UniqueKey()
3️⃣ GlobalKey
Access a widget’s state globally.
GlobalKey<FormState>()
4️⃣ PageStorageKey
Save and restore state (e.g., scroll position).
PageStorageKey<String>('scrollPosition')Example: Using Keys in a List
When reordering items in a list, keys help Flutter know which widgets moved:
List<Widget> items = [
ListTile(key: ValueKey('item1'), noscript: Text('Item 1')),
ListTile(key: ValueKey('item2'), noscript: Text('Item 2')),
];
Example: GlobalKey in a Form
Use a
GlobalKey to validate a form from anywhere: final GlobalKey<FormState> _formKey = GlobalKey<FormState>();
void _submit() {
if (_formKey.currentState!.validate()) {
print('Form is valid!');
}
}
Form(
key: _formKey,
child: Column(
children: [
TextFormField(validator: (value) => value!.isEmpty ? 'Required' : null),
ElevatedButton(onPressed: _submit, child: Text('Submit')),
],
),
);
When to Use Keys:
✅ Preserving State: Keep widget state intact during rebuilds.
✅ Reordering Widgets: Ensure Flutter correctly identifies moved widgets in a list.
✅ Accessing State: Use GlobalKey to access widget state from outside its subtree.
Why Are Keys Important?
Keys ensure Flutter can efficiently update the UI and maintain widget state. They’re essential for building dynamic, stateful, and performant apps.
❤5👎2
Flutter Accessibility Made Easy with
Ensuring your Flutter app is accessible is crucial for inclusivity. The
Here’s how to use it with examples:
1. Enable Accessibility
Wrap your
2. Check for Missing Semanticscs
The package warns you if a
❌ Before:
✅ After:
3. Detect Low Contrast Text
Ensures text is readable:
4. Check Tap Target Size
Buttons should be at least 48x48px:
❌ Too small:
✅ Fixed:
Why Use This?
✔️ Catch issues early
✔️ Improve app usability
✔️ Support screen readers & motor impairments
Get the package:
Try it in your project and make your app more inclusive!
accessibility_tools! Ensuring your Flutter app is accessible is crucial for inclusivity. The
accessibility_tools package helps you catch common accessibility issues during development. Here’s how to use it with examples:
1. Enable Accessibility
Wrap your
MaterialApp with AccessibilityTools: void main() {
runApp(
const AccessibilityTools(
child: MyApp(),
),
);
}2. Check for Missing Semanticscs
The package warns you if a
Text widget lacks semantics: ❌ Before:
Text('Click me') // Warning: Missing Semantics!✅ After:
Text(
'Click me',
semanticsLabel: 'Click me button', // Screen readers will announce this
)
3. Detect Low Contrast Text
Ensures text is readable:
Text(
'Low contrast',
style: TextStyle(color: Colors.grey[300]), // Warning: Low contrast!
)
4. Check Tap Target Size
Buttons should be at least 48x48px:
❌ Too small:
SizedBox(
width: 30,
height: 30,
child: IconButton(/*...*/), // Warning: Small tap target!
)
✅ Fixed:
IconButton(
iconSize: 48, // Meets minimum size
onPressed: () {},
icon: Icon(Icons.add),
)
Why Use This?
✔️ Catch issues early
✔️ Improve app usability
✔️ Support screen readers & motor impairments
Get the package:
dependencies:
accessibility_tools: ^latest_version
Try it in your project and make your app more inclusive!
❤5🔥4
Search-as-You-Type with Debouncing! 🔍
I'm excited to introduce a smoother & faster search experience in Flutter apps!
With this feature, users can get real-time results as they type, without unnecessary API calls.
How It Works?
✅ Search-as-you-type: Results update instantly with every keystroke.
✅ Debouncing: Reduces redundant API calls, improving performance.
✅ Optimized UX: No more lag or overload—just seamless searching!
💡 Why Debouncing?
Debouncing ensures that the app waits for a short pause (e.g., 300ms) before triggering a search. This prevents excessive network requests while keeping the search responsive!
Before: Typing "flutter" could trigger 6 API calls.
After: With debouncing, only 1 call is made after a brief pause.
👨💻 Flutter Implementation Sneak Peek
Here’s a snippet of how i did it with
🔥 Try it out now and enjoy lightning-fast searches!
I'm excited to introduce a smoother & faster search experience in Flutter apps!
With this feature, users can get real-time results as they type, without unnecessary API calls.
How It Works?
✅ Search-as-you-type: Results update instantly with every keystroke.
✅ Debouncing: Reduces redundant API calls, improving performance.
✅ Optimized UX: No more lag or overload—just seamless searching!
💡 Why Debouncing?
Debouncing ensures that the app waits for a short pause (e.g., 300ms) before triggering a search. This prevents excessive network requests while keeping the search responsive!
Before: Typing "flutter" could trigger 6 API calls.
After: With debouncing, only 1 call is made after a brief pause.
👨💻 Flutter Implementation Sneak Peek
Here’s a snippet of how i did it with
RxDart or Timer: final _searchController = TextEditingController();
final _debouncer = Debouncer(delay: Duration(milliseconds: 300));
_searchController.addListener(() {
_debouncer.run(() {
_fetchResults(_searchController.text);
});
});
🔥 Try it out now and enjoy lightning-fast searches!
🔥3👎2💯2❤1
Flutter FFI: How to Call C/C++ Code from Dart for Max Performance!
Did you know you can supercharge your Flutter apps by integrating native code?
With Flutter FFI (Foreign Function Interface), you can directly call C/C++ libraries from Dart, unlocking high-performance computing, hardware access, and legacy code reuse!
Why Use FFI?
✅ Performance Boost – Optimize CPU-heavy tasks with native code.
✅ Access Native APIs – Interact with platform-specific libraries.
✅ Reuse Existing Code – Integrate legacy C/C++ code without rewriting.
How It Works
Flutter FFI allows Dart to call functions from compiled native libraries (
You define the bindings in Dart and let the FFI handle the rest!
Quick Example
Use Cases
- Game Engines (e.g., integrating C++ physics engines)
- Media Processing (FFmpeg, OpenCV)
- Cryptography & Security (OpenSSL, custom encryption)
- IoT & Hardware (Bluetooth, sensors)
Getting Started
Official Flutter FFI Docs: https://docs.flutter.dev/development/platform-integration/c-interop
Did you know you can supercharge your Flutter apps by integrating native code?
With Flutter FFI (Foreign Function Interface), you can directly call C/C++ libraries from Dart, unlocking high-performance computing, hardware access, and legacy code reuse!
Why Use FFI?
✅ Performance Boost – Optimize CPU-heavy tasks with native code.
✅ Access Native APIs – Interact with platform-specific libraries.
✅ Reuse Existing Code – Integrate legacy C/C++ code without rewriting.
How It Works
Flutter FFI allows Dart to call functions from compiled native libraries (
.so, .dll, .dylib). You define the bindings in Dart and let the FFI handle the rest!
Quick Example
import 'dart:ffi';
import 'package:ffi/ffi.dart';
// Load native library
final dylib = DynamicLibrary.open('libnative.so');
// Define C function signature
typedef SumFunc = Int32 Function(Int32, Int32);
typedef Sum = int Function(int, int);
// Call native function
final sum = dylib.lookupFunction<SumFunc, Sum>('sum');
print(sum(5, 3)); // Output: 8
Use Cases
- Game Engines (e.g., integrating C++ physics engines)
- Media Processing (FFmpeg, OpenCV)
- Cryptography & Security (OpenSSL, custom encryption)
- IoT & Hardware (Bluetooth, sensors)
Getting Started
Official Flutter FFI Docs: https://docs.flutter.dev/development/platform-integration/c-interop
docs.flutter.dev
Build for and integrate with multiple platforms
Learn how to develop for different platforms and integrate with platform-specific features in Flutter apps.
🔥6💯2👎1
This media is not supported in your browser
VIEW IN TELEGRAM
Implementation of a Car Rental app Home Screen using Flutter
The training video is available on YouTube: https://youtu.be/Ji6mw_3i_Ew?si=CtXx3BvbwwGhzn5Z
The training video is available on YouTube: https://youtu.be/Ji6mw_3i_Ew?si=CtXx3BvbwwGhzn5Z
🔥8💯3👎2👏1