java - Kotlin AWS Rekognition 转换

标签 java android amazon-web-services kotlin amazon-rekognition

我目前正在移植一个用 Swift 构建的 iOS 应用程序。很快,我们可以通过以下方式进行重新识别调用:

将包导入到 podfile 后首先初始化客户端:

rekognitionClient = AWSRekognition.default()

然后创建一个“faceRequest”来调用该服务并查看您集合中的面孔是否与您发送的图像匹配:

guard let FaceRequest = AWSRekognitionSearchFacesByImageRequest() else
       {
           puts("Unable to initialize AWSRekognitionSearchfacerequest.")
           return
       }
       FaceRequest.collectionId = "MY_COLLECTION_NAME"
       FaceRequest.faceMatchThreshold = 75
       FaceRequest.maxFaces = 2
       let FacesourceImage = capturedImage
       let Faceimage = AWSRekognitionImage()
       Faceimage!.bytes = UIImageJPEGRepresentation(FacesourceImage!, 0.7)
       FaceRequest.image = Faceimage
       rekognitionClient.searchFaces(byImage:FaceRequest) { (response:AWSRekognitionSearchFacesByImageResponse?, error:Error?) in
           if error == nil
           {
               //print(response!)

               for faceMatch in (response?.faceMatches)! {
                     //do something
               }
           }
        }

我希望将其转换为 Kotlin,但在语法和发出请求方面遇到问题。我有一个位图格式的图像,可以发送到服务。

这是我一直在尝试的一个示例:

fun doRekognitionRequest(bitmap: Bitmap){

    //this says AmazonRekognitionClient has been deprecated
    val rekognitionClient = AmazonRekognitionClient()

    //unresolved reference
    val facesImageRequest = facesByImageRequest()
}

这是我的导入:

import android.Manifest
import android.app.Activity
import android.content.Context
import android.content.ContextWrapper
import android.content.Intent
import android.graphics.Bitmap
import android.graphics.Canvas
import android.graphics.SurfaceTexture
import android.graphics.drawable.BitmapDrawable
import android.hardware.camera2.*
import android.net.Uri
import android.os.*
import android.util.Log
import android.view.*
import android.widget.Toast
import androidx.core.content.ContextCompat
import androidx.fragment.app.Fragment
import androidx.fragment.app.FragmentTransaction
import kotlinx.android.synthetic.main.camera_layout.*
import pub.devrel.easypermissions.AfterPermissionGranted
import pub.devrel.easypermissions.EasyPermissions
import java.io.*
import java.io.File
import java.util.*
import android.provider.MediaStore
import androidx.core.content.FileProvider
import com.amazonaws.services.rekognition.AmazonRekognition;
import com.amazonaws.services.rekognition.AmazonRekognitionClient
import com.amazonaws.services.rekognition.model.FaceMatch;
import com.amazonaws.services.rekognition.model.Image;
import com.amazonaws.services.rekognition.model.S3Object;
import com.amazonaws.services.rekognition.model.SearchFacesByImageRequest;
import com.amazonaws.services.rekognition.model.SearchFacesByImageResult;

我正在尝试以这个人所做的事情为基础:https://github.com/awslabs/serverless-photo-recognition/blob/master/src/main/kotlin/com/budilov/rekognition/RekognitionService.kt

以及尝试将 java 示例代码从 rekognition 文档转换为 Kotlin,但没有成功。

https://docs.aws.amazon.com/rekognition/latest/dg/search-face-with-image-procedure.html

   AmazonRekognition rekognitionClient = AmazonRekognitionClientBuilder.defaultClient();

  ObjectMapper objectMapper = new ObjectMapper();

   // Get an image object from S3 bucket.
  Image image=new Image()
          .withS3Object(new S3Object()
                  .withBucket(bucket)
                  .withName(photo));

  // Search collection for faces similar to the largest face in the image.
  SearchFacesByImageRequest searchFacesByImageRequest = new SearchFacesByImageRequest()
          .withCollectionId(collectionId)
          .withImage(image)
          .withFaceMatchThreshold(70F)
          .withMaxFaces(2);

   SearchFacesByImageResult searchFacesByImageResult = 
           rekognitionClient.searchFacesByImage(searchFacesByImageRequest);

   System.out.println("Faces matching largest face in image from" + photo);
  List < FaceMatch > faceImageMatches = searchFacesByImageResult.getFaceMatches();
  for (FaceMatch face: faceImageMatches) {
      System.out.println(objectMapper.writerWithDefaultPrettyPrinter()
              .writeValueAsString(face));
     System.out.println();
  }

Kotlin 和 Android 对我来说都很陌生,我有 C# 和 Swift 背景,因此我们将不胜感激。 干杯!

编辑:

设法让 searchfacesbyImageRequest 构造函数被编译器看到。现在一直致力于将位图转换为图像。

    val facesImageRequest = SearchFacesByImageRequest()
    facesImageRequest.collectionId = "MY_COLLECTION_NAME"
    facesImageRequest.maxFaces = 2
    facesImageRequest.faceMatchThreshold = 75.0F
    facesImageRequest.image = Image(bitmap)

最佳答案

这是一种从 android.graphics.Bitmap 构造 com.amazonaws.services.rekognition.model.Image 的方法

val bitmap : Bitmap? = // Source of your picture
val byteBuffer = ByteBuffer.allocate(bitmap.byteCount)
bitmap?.copyPixelsToBuffer(byteBuffer)
val image = Image().withBytes(byteBuffer)

关于java - Kotlin AWS Rekognition 转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51547437/

相关文章:

Java线程join()与 sleep 间隔导致问题

java - Sqlite 查询检查 - 小于和大于

android - SQLiteDatabase.query 是否使用 PreparedStatements ?

postgresql - AWS数据库单列添加极多数据

java - 使 JAR 可用于 JDK 和 JRE

java - (Java) 从内存中删除一个实例?

java - Android 以编程方式获取特定应用程序的数据使用情况,例如 : Data Usage used on "Facebook"

android - 如何在Android中设置古吉拉特语联合词?

amazon-web-services - 如何对 AWS S3 存储桶访问进行速率限制

amazon-web-services - 如何使用 golang 检查 s3 对象大小