The document only describes the equivalent changes to the API. If you want to see the new feature support, please refer to readme and change log.
This version mainly covers all valid issues, API deprecations, and few new features.
- The org name has been updated from
top.kikt
tocom.fluttercandies
. - The plugin name on native side has been updated from
ImageScanner
toPhotoManager
. AssetPathEntity
andAssetEntity
are now immutable.title
are required when using saving methods.RequestType.common
is the default type for all type request.- Arguments with
getAssetListPaged
are now required with name. PhotoManager.notifyingOfChange
has no setter anymore.PhotoManager.refreshAssetProperties
andPhotoManager.fetchPathProperties
have been moved to entities.containsLivePhotos
aretrue
by default. If you previously usedRequestType.video
to filter assets, they'll include live photos now. To keep to old behavior, you should explicitly setcontainsLivePhotos
tofalse
in this case.isLocallyAvailable
now passesisOrigin
, so it's been changed toisLocallyAvailable()
.
There are several APIs have been removed, since they can't provide precise meanings, or can be replaced by new APIs. If you've used these APIs, consider migrating them to the latest version.
Removed API/class/field | Migrate destination |
---|---|
PhotoManager.getImageAsset |
PhotoManager.getAssetPathList(type: RequestType.image) |
PhotoManager.getVideoAsset |
PhotoManager.getAssetPathList(type: RequestType.video) |
PhotoManager.fetchPathProperties |
AssetPathEntity.fetchPathProperties |
PhotoManager.refreshAssetProperties |
AssetEntity.refreshProperties |
PhotoManager.requestPermission |
PhotoManager.requestPermissionExtend |
AssetPathEntity.assetList |
N/A, use pagination APIs instead. |
AssetPathEntity.refreshPathProperties |
AssetPathEntity.obtainForNewProperties |
AssetEntity.createDtSecond |
AssetEntity.createDateSecond |
AssetEntity.fullData |
AssetEntity.originBytes |
AssetEntity.thumbData |
AssetEntity.thumbnailData |
AssetEntity.refreshProperties |
AssetEntity.obtainForNewProperties |
FilterOptionGroup.dateTimeCond |
FilterOptionGroup.createTimeCond |
ThumbFormat |
ThumbnailFormat |
ThumbOption |
ThumbnailOption |
Before:
AssetPathEntity.getAssetListPaged(0, 50);
After:
AssetPathEntity.getAssetListPaged(page: 0, size: 50);
Before:
final List<AssetPathEntity> paths = PhotoManager.getAssetPathList(type: RequestType.video);
After:
final List<AssetPathEntity> paths = PhotoManager.getAssetPathList(
type: RequestType.video,
filterOption: FilterOptionGroup(containsLivePhotos: false),
);
Before:
final bool isLocallyAvailable = await entity.isLocallyAvailable;
After:
// .file is locally available.
final bool isFileLocallyAvailable = await entity.isLocallyAvailable();
// .originFile is locally available.
final bool isOriginFileLocallyAvailable = await entity.isLocallyAvailable(
isOrigin: true,
);
Before:
final bool isSucceed = await PhotoManager.editor.iOS.favoriteAsset(
entity: entity,
favorite: true,
);
After:
/// If succeed, a new entity will be returned.
final AssetEntity? newEntity = await PhotoManager.editor.iOS.favoriteAsset(
entity: entity,
favorite: true,
);
This version is a null-safety version.
Please read document for null-safety information in dart or flutter.
Before:
final dtCond = DateTimeCond(
min: startDt,
max: endDt,
asc: asc,
)..dateTimeCond = dtCond;
After:
final dtCond = DateTimeCond(
min: startDt,
max: endDt,
);
final orderOption = OrderOption(
type: OrderOptionType.createDate,
asc: asc,
);
final filterOptionGroup = FilterOptionGroup()..addOrderOption(orderOption);