data:image/s3,"s3://crabby-images/56b4b/56b4b96640e52c06cb87a99a07fc88b652df6740" alt=""
Davinci is a powerful package that allows you to convert any widget into an image, which can be saved locally or shared across apps and chats. Perfect for creating snapshots of your UI! đ¸
đ ī¸ Supported Platforms
Platform | Status |
---|---|
Android | â |
iOS | â |
Web | â |
Feel free to test it on other platforms and report back with your findings! đ
đš Preview
data:image/s3,"s3://crabby-images/6c7c1/6c7c18b3d74e0a1167b52dab715b7fae4b7d5c53" alt=""
Prerequisites
For iOS
Add the following keys to your Info.plist file, located in <project root>/ios/Runner/Info.plist
:
NSPhotoLibraryUsageDescription
- Describe why your app needs permission for the photo library. This is called Privacy - Photo Library Usage Description in the visual editor.
For Android
Add the following permission to your AndroidManifest.xml
:
android.permission.WRITE_EXTERNAL_STORAGE
- Permission for usage of external storage.
âšī¸ Usage
Imports
import 'package:davinci/core/davinci_capture.dart';
import 'package:davinci/davinci.dart';
Code
If the widget is in the widget tree, use the click
method:
data:image/s3,"s3://crabby-images/01fbd/01fbd478d88f468b41d4a13c05af557f0ba03bd3" alt=""
If the widget is not in the widget tree, use the offStage
method:
data:image/s3,"s3://crabby-images/8aeb7/8aeb7e9e9a276e9cfe99e0a3b5f6354ebd2a52f4" alt=""
đ¨ Customization
data:image/s3,"s3://crabby-images/4a81b/4a81b70e89156cfff8ed399c762adcd9e166daf9" alt=""
âšī¸ All the parameters in the click
method are present in the offStage
method except the brandTag
prop.
đī¸ Note:
- If you wish to save the generated images locally, do remember to add the necessary permissions in
Info.plist
andAndroidManifest.xml
.