Невозможно вернуть обновленное значение (base64Image) при вызове функции - PullRequest
0 голосов
/ 16 апреля 2019

В моем ионном проекте я пишу сервис для возврата изображения 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>

Что именно мне нужно сделать, чтобы возвращаемое значение было самым последним?

...