强大的图片浏览器---------增强、降低透明度、切换下一张

本文介绍了一个基于Android的图像处理应用实例,通过按钮控制图像的透明度变化,并实现触摸屏幕预览图像局部区域的功能。文章详细展示了如何使用Java和XML布局实现这一功能,包括动态调整图像透明度和响应触摸事件。
摘要由CSDN通过智能技术生成

 

 

xml-------布局-----------------------------------

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">

<LinearLayout
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<Button
android:id="@+id/plus"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="增大透明度"
/>
<Button
android:id="@+id/minus"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="降低透明度"
/>
<Button
android:id="@+id/next"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="下一张"
/>
</LinearLayout>

<ImageView
android:id="@+id/image1"
android:layout_width="wrap_content"
android:layout_height="280dp"
android:src="@drawable/img3"
android:scaleType="fitCenter"/>
<ImageView
android:id="@+id/image2"
android:layout_width="120dp"
android:layout_height="120dp"
android:background="#00f"
android:layout_margin="10dp"/>
</LinearLayout>




MainActivity.java-----------------Java调用----------------------------------

  int[] images=new int[]{
R.drawable.img1,
R.drawable.img2,
R.drawable.img3,
R.drawable.img4,
R.drawable.img5,

};
int currentIMG=2;
private int alpha=255;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.imageviewer);
final Button plus=(Button) findViewById(R.id.plus);
final Button minus=(Button) findViewById(R.id.minus);
final ImageView image1=(ImageView) findViewById(R.id.image1);
final ImageView image2=(ImageView) findViewById(R.id.image2);
final Button next=(Button) findViewById(R.id.next);
next.setOnClickListener(new View.OnClickListener(){
@Override
public void onClick(View v) {
image1.setImageResource(images[++currentIMG%images.length]);
}
});
View.OnClickListener listener=new View.OnClickListener(){
@TargetApi(Build.VERSION_CODES.JELLY_BEAN)
@Override
public void onClick(View v){
if(v==plus){
alpha+=20;
}
if(v==minus){
alpha-=20;
}
if(alpha>=255){
alpha=255;
}
if(alpha<=0){
alpha=0;
}
image1.setImageAlpha(alpha);
}
};

plus.setOnClickListener(listener);
minus.setOnClickListener(listener);
image1.setOnTouchListener(new View.OnTouchListener() {
@TargetApi(Build.VERSION_CODES.JELLY_BEAN)
@Override
public boolean onTouch(View v, MotionEvent event) {
BitmapDrawable bitmapDrawable=(BitmapDrawable) image1.getDrawable();
Bitmap bitmap=bitmapDrawable.getBitmap();
double scale=1.0*bitmap.getHeight()/image1.getHeight();
int x=(int) (event.getX()*scale);
int y=(int) (event.getY()*scale);
if(x+120>bitmap.getWidth()){
x=bitmap.getWidth()-120;
}
if(y+120>bitmap.getHeight()){
y=bitmap.getHeight()-120;
}
image2.setImageBitmap(Bitmap.createBitmap(bitmap,x,y,120,120));
image2.setImageAlpha(alpha);
return false;
}
});
}

转载于:https://www.cnblogs.com/ZeroMurder/p/5929938.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值