介绍
本示例将通过发布图片评论场景,介绍如何使用startAbilityForResult接口拉起相机拍照,并获取相机返回的数据。
效果图预览
使用说明
- 通过startAbilityForResult接口拉起相机,拍照后获取图片地址。
实现思路
- 创建CommentData类,实现IDataSource接口的对象,用于评论列表使用LazyForEach加载数据。
export class CommentData extends BasicDataSource {
// 懒加载数据
private comments: Array<Comment> = [];
// TODO:知识点:获取懒加载数据源的数据长度
totalCount(): number {
return this.comments.length;
}
// 获取指定数据项
getData(index: number): Comment {
return this.comments[index];
}
// TODO:知识点:存储数据到懒加载数据源中
pushData(data: Comment): void {
this.comments.push(data);
AppStorage.setOrCreate('commentCount', this.totalCount());
// 在数组头部添加数据
this.notifyDataAdd(this.comments.length - 1);
}
}
- 点击下方输入提示框,拉起评论输入弹窗。
Text($r('app.string.text_input_hint'))
...
.onClick(() => {
if (this.dialogController != null) {
// 打开评论输入弹窗
this.dialogController.open();
}
})
3.在输入弹窗中,输入文字,点击相机按钮,拉起相机,拍照后获得返回的图片地址。
Image($r('app.media.camera'))
...
.onClick(async () => {
...
let image: string = await cameraCapture(getContext(this