В моем ионном проекте я пишу сервис для возврата изображения base64, по которому щелкала собственная камера устройства, после вызова функции.
Проблема в том, что когда я вызываю функцию в сервисе, оператор return возвращает старое значение, а не обновленное значение, которое должно быть по нажатию изображения.
Например, я пытаюсь установить профиль пользователя, изображение, которое он показывает, является вторым последним нажатием на изображение, а не самым последним изображением.
Первоначально я сохранил значение в переменной и получил к нему доступ напрямую.
Позже я вернул значение при вызове функции
Обслуживание камеры
import { Injectable } from "@angular/core";
import { Camera, CameraOptions } from "@ionic-native/camera/ngx";
import { Platform } from "@ionic/angular";
@Injectable({
providedIn: "root"
})
export class CameraCordovaService {
constructor(private camera: Camera, public platform: Platform) {}
base64Image: string;
takePicture(): string {
const options: CameraOptions = {
quality: 30,
destinationType: this.camera.DestinationType.DATA_URL,
encodingType: this.camera.EncodingType.JPEG,
mediaType: this.camera.MediaType.PICTURE
};
this.platform.ready().then(() => {
this.camera.getPicture(options).then(
imageData => {
//this.base64Image = "data:image/jpeg;base64," + imageData;
let tempImg="data:image/jpeg;base64," + imageData;
this.base64Image=tempImg
console.log(this.base64Image);
},
err => {
// Handle error
console.log("Camera issue: " + err);
}
);
});
return this.base64Image;
}
}
Файл машинописного текста страницы, на которой используется этот плагин камеры
import { ActionSheetController } from "@ionic/angular";
import { CameraCordovaService } from "../plugins/camera-services/camera-cordova.service";
@Component({
selector: "app-tab2",
templateUrl: "tab2.page.html",
styleUrls: ["tab2.page.scss"]
})
export class Tab2Page {
imgProfile: string =
"";
constructor(
public Camera: CameraCordovaService,
public actionSheetController: ActionSheetController
) {}
async presentActionSheet() {
const actionSheet = await this.actionSheetController.create({
header: "Profile Picture",
buttons: [
{
text: "Camera",
role: "destructive",
icon: "camera",
handler: () => {
console.log("Camera");
this.imgProfile = this.Camera.takePicture();
console.log(this.imgProfile);a
}
},
{
text: "Gallery",
icon: "share",
handler: () => {
console.log("Gallery clicked");
}
},
{
text: "Cancel",
icon: "close",
role: "cancel",
handler: () => {
console.log("Cancel clicked");
}
}
]
});
await actionSheet.present();
}
}
ФАЙЛ HTML
<ion-item (click)="presentActionSheet()">
<ion-label>Avatar</ion-label>
<ion-avatar>
<img [src]="imgProfile" />
</ion-avatar>
</ion-item>
Что именно мне нужно сделать, чтобы возвращаемое значение было самым последним?