![](/img/trans.png)
[英]Android-Image-Cropper Menu item Actionlistener is not working
[英]Android-Image-Cropper to circle
我正在尝试将我的图像裁剪成一个圆圈,为此我正在使用提供的 Android-Image-Cropper 库 - 'com.theartofdev.edmodo:android-image-cropper:2.4.+' 目前我能够选择一个图像,裁剪 window 显示为一个圆圈,虽然它不会裁剪成一个圆圈,而是一个正方形。
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == GALLERY_REQUEST && resultCode == RESULT_OK) {
Uri imageUri = data.getData();
CropImage.activity(imageUri)
.setAspectRatio(150,150)
.setGuidelines(CropImageView.Guidelines.ON)
.setCropShape(CropImageView.CropShape.OVAL)
.start(this);
}
if (requestCode == CropImage.CROP_IMAGE_ACTIVITY_REQUEST_CODE) {
CropImage.ActivityResult result = CropImage.getActivityResult(data);
if (resultCode == RESULT_OK) {
mImageUri = result.getUri();
mSetupImageBtn.setImageURI(mImageUri);
} else if (resultCode == CropImage.CROP_IMAGE_ACTIVITY_RESULT_ERROR_CODE) {
Exception error = result.getError();
}
}
}
您可以像第一条评论中提到的那样使用 glide 如何使用 Glide 库舍入图像?
其次,你可以使用下面的库编译'de.hdodenhof:circleimageview:1.2.1'
使用 Picasso 你可以使用上面的圆形图像库 ab 可以使用 picasso 在其中加载图像,如下所示:
Picasso.with(activity).load(url).into(ImageView);
例子:
<de.hdodenhof.circleimageview.CircleImageView
android:id="@+id/img_profile"
android:layout_width="100dp"
android:layout_height="100dp" />
Picasso.with(activity).load(url).into(ImageView);
如果您不想使用 circleImageView,那么您可以按照此链接评论中的使用创建一个转换
不再支持ArthurHub/Android-Image-Cropper ( 在此处阅读更多信息)。 所以你可以迁移到一个支持圆形裁剪的新项目CanHub/Android-Image-Cropper function。
示例如下:
将CropImageVIew
添加到您的标记中:
<com.canhub.cropper.CropImageView
android:id="@+id/cropView"
android:layout_width="0dp"
android:layout_height="0dp"
app:cornerShape="rectangle" />
在片段或活动中设置图像:
binding.cropView.setImageUriAsync(imageUri)
将结果侦听器添加到cropView
:
binding.cropView.setOnCropImageCompleteListener { view, result ->
// !!! You should use result.getBitmap(ctx), because result.bitmap returns null !!!
// Read more here: https://github.com/CanHub/Android-Image-Cropper/pull/70
val imageBitmap = result.getBitmap(requireContext())!!
val ovalBitmap = CropImage.toOvalBitmap(imageBitmap)
// Now you can save ovalBitmap to file or set it to ImageView with setImageBitmap()
}
将点击侦听器添加到您的“裁剪按钮” :
binding.cropImageButton.setOnClickListener {
binding.cropView.croppedImageAsync()
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.