С помощью ACTION_IMAGE_CAPTURE получить полноразмерное растровое изображение kotlin - PullRequest
0 голосов
/ 11 мая 2018

Все, что я хочу сделать, это разрешить пользователям делать фотографии, а затем, после того как они закончат заполнять форму, отправить эту фотографию и загрузить на сервер. Я думаю, что мне нужно изображение в виде растрового изображения, чтобы я мог преобразовать в строку Base64. Я пробовал несколько разных вещей, которые нашел, но ни одна из них не работает. Я получаю либо ошибки каталога, либо намеренные ошибки NULL.

class Register : AppCompatActivity(), View.OnClickListener {
    var  PlayerID = ""
    var mCurrentPhotoPath = ""
    var stuff: File? = null

    private var filePath: Uri? = null
    private val PICK_IMAGE_REQUEST = 1
    @RequiresApi(Build.VERSION_CODES.O)



    override fun onClick(v: View?) {
      if(v === buttonLoadPicture)
          showFileChooser()
        else if (v == btn_register)
          uploadFile()
    }

    override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent) {
            if (resultCode != RESULT_CANCELED) {
                if (requestCode == PICK_IMAGE_REQUEST) {

                    val thumbnail = MediaStore.Images.Media.getBitmap(getContentResolver(), filePath)
                    PhotoImageView.setImageBitmap(thumbnail)

                    filePath = getRealPathFromURI(Uri.parse(filePath.toString()))
                }
            }
        }


    //////////////
    fun  getImageUri(inContext: Context , inImage: Bitmap): Uri {
        val bytes = ByteArrayOutputStream()
        inImage.compress(Bitmap.CompressFormat.PNG, 100, bytes)
        val path = MediaStore.Images.Media.insertImage(inContext.getContentResolver(), inImage, "Title", null)
        return Uri.parse(path)
    }

     fun getRealPathFromURI(uri: Uri): Uri? {
         val proj = arrayOf(MediaStore.Images.Media.DATA)
        val cursor = getContentResolver().query(uri, proj, null, null, null)

        cursor.moveToFirst()
        val idx = cursor.getColumnIndex(MediaStore.Images.ImageColumns.DATA)
        return Uri.parse(cursor.getString(idx))
    }


    ////////////////
    @RequiresApi(Build.VERSION_CODES.N)
    private fun showFileChooser() {
        if (ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA)
                != PackageManager.PERMISSION_GRANTED) {
            ActivityCompat.requestPermissions(this,
                    arrayOf(Manifest.permission.CAMERA),
                    1)
        }

        if (ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)
                != PackageManager.PERMISSION_GRANTED) {
            ActivityCompat.requestPermissions(this,
                    arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE),
                    1)
        }

        val intent = Intent(MediaStore.ACTION_IMAGE_CAPTURE)
        startActivityForResult(intent, 1)
    }





    val jsonobject = JSONObject()
    @RequiresApi(Build.VERSION_CODES.O)
    private fun uploadFile() {
        val progress: ProgressBar = progressBarR
        progress.visibility= View.VISIBLE

        val iStream = contentResolver.openInputStream(filePath)
        val bitmap = BitmapFactory.decodeStream(iStream)
        val baos = ByteArrayOutputStream()
        bitmap.compress(Bitmap.CompressFormat.JPEG, 100, baos)
        val m = baos.toByteArray()
        val imageString = Base64.encodeToString(m,Base64.DEFAULT)



        //get form data from register layout
            jsonobject.put("FirstName", input_fname.text)
            jsonobject.put("LastName", input_lname.text)
            jsonobject.put("UserName", input_username.text)
            jsonobject.put("Phone", input_phone.text)
            jsonobject.put("DOB", input_DOB.text)
            jsonobject.put("Photo", imageString)
            jsonobject.put("Profile", input_profile.text)
            jsonobject.put("Email", input_email.text)
            jsonobject.put("Password", input_password.text)
            jsonobject.put("ConfirmPassword", input_confirm.text)

           var url = "https://elimination.azurewebsites.net/api/Account/Post"

            val que = Volley.newRequestQueue(this@Register)
            val req = JsonObjectRequest(Request.Method.POST, url, jsonobject,
                    Response.Listener<JSONObject>{
                        response -> response.toString()
                        //save PlayerID to val PlayerID
                        PlayerID  =  response.get("PlayerID").toString()
                        //save to sharedPreferences
                        val email = input_email.text.toString()
                        val mypref = getSharedPreferences(email, Context.MODE_PRIVATE)
                        val editor = mypref.edit()
                        editor.putString(email, PlayerID)
                        editor.apply()

                        val intent = Intent(this, Login::class.java)
                        startActivity(intent)
                    },
                    Response.ErrorListener{
                    response ->
                Log.e("Something went wrong", response.toString())
            })
        //if server is slow
        val socketTimeout = 30000 // 30 seconds
        val policy = DefaultRetryPolicy(socketTimeout,
                DefaultRetryPolicy.DEFAULT_MAX_RETRIES,
                DefaultRetryPolicy.DEFAULT_BACKOFF_MULT)
        req.setRetryPolicy(policy)
        // Adding request to request queue
            que.add(req)
        }

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_register)
        buttonLoadPicture.setOnClickListener(this)
        btn_register.setOnClickListener(this)
    }
}

1 Ответ

0 голосов
/ 11 мая 2018
    val intent = Intent(MediaStore.ACTION_IMAGE_CAPTURE)
    startActivityForResult(intent, 1)

Вы вызываете ACTION_IMAGE_CAPTURE без EXTRA_OUTPUT.

override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent) {
        if (resultCode != RESULT_CANCELED) {
            if (requestCode == PICK_IMAGE_REQUEST) {

                val thumbnail = MediaStore.Images.Media.getBitmap(getContentResolver(), filePath)
                PhotoImageView.setImageBitmap(thumbnail)

                filePath = getRealPathFromURI(Uri.parse(filePath.toString()))
            }
        }
    }

Вы не используете Bitmap, который вы получаете от ACTION_IMAGE_CAPTURE, когда вы не поставляете EXTRA_OUTPUT,Вместо этого вы ищете значение filePath, которое вполне может быть null и определенно не имеет ничего общего с фотографией, которую могло сделать выбранное пользователем приложение камеры.

Если вы хотите сообщить камереприложение, где разместить полноразмерное фото, используйте EXTRA_OUTPUT.Однако имейте в виду, что вы вряд ли сможете преобразовать полноразмерную фотографию в base64, так как у вас закончится память.

...