在 Android 中使用 TouchEvents 从图像中选择颜色
在本文中,我们将学习如何在图像上获得触摸像素颜色。下面给出了一个屏幕截图,以了解我们将在本文中做什么。请注意,我们将使用Kotlin语言来实现这个项目。
分步实施
第 1 步:要在 Android Studio 中创建新项目,请参阅如何在 Android Studio 中创建/启动新项目。请注意,选择Kotlin作为编程语言。
第 2 步:在布局中设置任何图像
导航到app > res > layout > activity_main.xml并将以下代码添加到该文件中。下面是activity_main.xml文件的代码。
XML
Kotlin
import android.annotation.SuppressLint
import android.graphics.Bitmap
import android.graphics.Color
import android.os.Bundle
import android.view.MotionEvent
import android.view.View
import android.widget.ImageView
import android.widget.TextView
import androidx.appcompat.app.AppCompatActivity
class MainActivity : AppCompatActivity() {
lateinit var image: ImageView
lateinit var bitmap: Bitmap
lateinit var colorView: View
lateinit var colorString: TextView
@SuppressLint("ClickableViewAccessibility")
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
image = findViewById(R.id.pickColorImage)
colorView = findViewById(R.id.fillColor)
colorString = findViewById(R.id.colorInHex)
image.isDrawingCacheEnabled = true
image.buildDrawingCache(true)
// on touch listener on image view
image.setOnTouchListener { _, event ->
if (event.action == MotionEvent.ACTION_DOWN || event.action == MotionEvent.ACTION_MOVE) {
bitmap = image.drawingCache
// get touched pixel
val pixel = bitmap.getPixel(event.x.toInt(), event.y.toInt())
// get RGB values from the touched pixel
val r = Color.red(pixel)
val g = Color.green(pixel)
val b = Color.blue(pixel)
// color name in Hexadecimal(#RRGGBB)
colorString.text = "#${Integer.toHexString(pixel)}"
// fill the color in the view
colorView.setBackgroundColor(Color.rgb(r, g, b))
}
true
}
}
}
步骤 3:使用 MainActivity.kt 文件
转到MainActivity.kt文件并参考以下代码。下面是MainActivity.kt文件的代码。代码中添加了注释以更详细地理解代码。
科特林
import android.annotation.SuppressLint
import android.graphics.Bitmap
import android.graphics.Color
import android.os.Bundle
import android.view.MotionEvent
import android.view.View
import android.widget.ImageView
import android.widget.TextView
import androidx.appcompat.app.AppCompatActivity
class MainActivity : AppCompatActivity() {
lateinit var image: ImageView
lateinit var bitmap: Bitmap
lateinit var colorView: View
lateinit var colorString: TextView
@SuppressLint("ClickableViewAccessibility")
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
image = findViewById(R.id.pickColorImage)
colorView = findViewById(R.id.fillColor)
colorString = findViewById(R.id.colorInHex)
image.isDrawingCacheEnabled = true
image.buildDrawingCache(true)
// on touch listener on image view
image.setOnTouchListener { _, event ->
if (event.action == MotionEvent.ACTION_DOWN || event.action == MotionEvent.ACTION_MOVE) {
bitmap = image.drawingCache
// get touched pixel
val pixel = bitmap.getPixel(event.x.toInt(), event.y.toInt())
// get RGB values from the touched pixel
val r = Color.red(pixel)
val g = Color.green(pixel)
val b = Color.blue(pixel)
// color name in Hexadecimal(#RRGGBB)
colorString.text = "#${Integer.toHexString(pixel)}"
// fill the color in the view
colorView.setBackgroundColor(Color.rgb(r, g, b))
}
true
}
}
}
现在,运行应用程序
输出:
源代码:点击这里
想要一个更快节奏和更具竞争力的环境来学习 Android 的基础知识吗?
单击此处前往由我们的专家精心策划的指南,旨在让您立即做好行业准备!