本文介绍: Android拼接合并图片生成长图代码实现合并两张图片,以第一张图片的宽度为标准,如果被合并的第二张图片宽度和第一张不同,那么就以第一张图片的宽度为准线,对第二张图片进行缩放。Android拼接合并图片生成长图代码实现合并两张图片,以第一张图片的宽度为标准,如果被合并的第二张图片宽度和第一张不同,那么就以第一张图片的宽度为准线,对第二张图片进行缩放。基础上,把剪切的区域从矩形Rect变为圆形的Path,当手指在上面的ImageView移动时候,下面同等大小对应的坐标区域显示“剪切”出来的圆形图。
Android矩阵Matrix变换setRectToRect,Kotlin
在 Android画布Canvas裁剪区域clipRect,Kotlin-CSDN博客 基础上,增加一个点,通过setRectToRect挖出Bitmap原图中心区域的一块放到目标RectF里面。
import android.content.Context
import android.graphics.Bitmap
import android.graphics.Canvas
import android.graphics.Color
import android.graphics.Matrix
import android.graphics.RectF
import android.graphics.drawable.BitmapDrawable
import android.os.Bundle
import android.util.AttributeSet
import android.util.SizeF
import android.widget.ImageView
import androidx.appcompat.app.AppCompatActivity
import androidx.appcompat.widget.AppCompatImageView
class MainActivity : AppCompatActivity() {
private var iv: MyImageView? = null
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
iv = findViewById(R.id.iv)
val result = findViewById<ImageView>(R.id.result)
iv?.setTestImageView(result)
}
}
class MyImageView : AppCompatImageView {
private var mSrcBmp: Bitmap? = null
private var testIV: ImageView? = null
private val mSizeF = SizeF(500f, 200f)
constructor(ctx: Context, attrs: AttributeSet) : super(ctx, attrs) {
//mSrcBmp是原始图大小,没有缩放和拉伸的。
mSrcBmp = (drawable as BitmapDrawable).bitmap
}
fun setTestImageView(imageView: ImageView) {
testIV = imageView
}
override fun onDraw(canvas: Canvas) {
val cx = this.width / 2
val cy = this.height / 2
val srcRectF = RectF(cx - mSizeF.width / 2, cy - mSizeF.height / 2, cx + mSizeF.width / 2, cy + mSizeF.height / 2)
canvas.clipRect(srcRectF)
super.onDraw(canvas)
val bmp = Bitmap.createBitmap(mSizeF.width.toInt(), mSizeF.height.toInt(), Bitmap.Config.ARGB_8888)
val c = Canvas(bmp)
c.drawColor(Color.BLUE)
//选取源bitmap的一块中心区域。
val bmpCenterX = mSrcBmp!!.width / 2
val bmpCenterY = mSrcBmp!!.height / 2
val bmpRectF = RectF(
bmpCenterX - mSizeF.width / 2,
bmpCenterY - mSizeF.height / 2,
bmpCenterX + mSizeF.width / 2,
bmpCenterY + mSizeF.height / 2
)
val dstRectF = RectF(0f, 0f, mSizeF.width, mSizeF.height)
val matrix = Matrix()
//把bitmap中心区域的那一块放到目标的dstRectF里面。
matrix.setRectToRect(bmpRectF, dstRectF, Matrix.ScaleToFit.CENTER)
c.drawBitmap(mSrcBmp!!, matrix, null)
testIV?.setImageBitmap(bmp)
}
}
上图是clipRect裁剪剪切区域绘制出来的中心区域图。
下面是setRectToRect“挖”出Bitmap中心区域的一块放到目标Bitmap里面。
原文地址:https://blog.csdn.net/zhangphil/article/details/135913218
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_66183.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。