jag*_*ish 5 android imageview colorfilter
我正在为发型沙龙开发一个android应用程序。我有两个图像。一种是发型(头发),另一种是头发的颜色样式。我可以根据特定的rgb值更改发型的颜色。
我的代码如下:
int color = Color.rgb(182,132, 84); // getting rgb value
Paint paint = new Paint();
paint.setColorFilter(new LightingColorFilter(color, 1));
transform.reset();
transform.postTranslate(-width / 2.0f, -height / 2.0f);
transform.postRotate(getDegreesFromRadians(angle));
transform.postScale(scale, scale);
transform.postTranslate(position.getX(), position.getY());
canvas.drawBitmap(bitmap, transform, paint);
Run Code Online (Sandbox Code Playgroud)
但是我正在寻找的解决方案假设我有彩色图案图像,那么就不可能从渐变图像中获得rgb值。
喜欢:


我想在头发图像上应用上述图案。如果有人有主意,请回复。
只是出于乐趣和好奇心,我尝试自己实现你的想法。
准备好以下两个 xxhdpi 图像(480 dpi,以便使它们能够很好地缩放 - 然后我将它们放入文件夹中/res/drawable-xxhdpi)后
当然,我必须仔细调整图像的大小,以使其完美贴合和重叠。
和一根白发(你的复制品,“发白”——去饱和度+调整亮度/对比度)
我做了这样的布局,其中头发图像与头部重叠:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#f000"
>
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:src="@drawable/head_xxh"
/>
<ImageView
android:id="@+id/imgHair"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:src="@drawable/hair_wht_xxh"
/>
<Button
android:id="@+id/btnColor"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:text="Random hair color"
android:onClick="clickHandler"
/>
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)
这是我使用的代码:
package com.dergolem.abc_2;
import java.util.Random;
import android.app.Activity;
import android.graphics.Color;
import android.graphics.PorterDuff;
import android.os.Bundle;
import android.view.View;
import android.view.Window;
import android.widget.Button;
import android.widget.ImageView;
public class Generic
extends Activity
{
Random rnd = new Random();
Button btn = null;
ImageView img = null;
@Override
public void onCreate(final Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.hair);
img = (ImageView) findViewById(R.id.imgHair);
btn = (Button) findViewById(R.id.btnColor);
}
public void clickHandler(final View v)
{
colorize(rnd.nextInt(7));
}
private void colorize(final int num)
{
int clr = Color.WHITE;
switch (num)
{
case 0:
{
clr = Color.RED;
break;
}
case 1:
{
clr = Color.GREEN;
break;
}
case 2:
{
clr = Color.BLUE;
break;
}
case 3:
{
clr = Color.BLACK;
break;
}
case 4:
{
clr = Color.CYAN;
break;
}
case 5:
{
clr = Color.YELLOW;
break;
}
case 6:
{
clr = Color.parseColor("#ff888800");
break;
}
}
img.setColorFilter(clr, PorterDuff.Mode.MULTIPLY);
}
}
Run Code Online (Sandbox Code Playgroud)
我得到的一些结果:

即使这张作品看起来像安迪·沃罗尔的照片,但事实并非如此。这是我的。:)
这似乎是您正在寻找的结果。
[编辑]
我没有尝试这个新想法,但是(通过一些额外的工作)你甚至可以更改其他颜色:
| 归档时间: |
|
| 查看次数: |
1835 次 |
| 最近记录: |