Android实现图片浏览并改变透明度

 更新时间:2020年08月25日 12:35:02   作者:池头树  
这篇文章主要为大家详细介绍了Android实现图片浏览并改变透明度,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了简单的图片浏览器制作,供大家参考,具体内容如下

例子中的图片浏览器既可以改变图片的透明度,也可以根据用户在图片上选定的某一区域,对其进行显示,用于查看图片的局部细节。

在activity_main.xml中:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:app="http://schemas.android.com/apk/res-auto"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:orientation="vertical"
 android:layout_height="match_parent"
 tools:context=".MainActivity">
 <LinearLayout
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:orientation="horizontal"
 android:gravity="center">
 <Button
  android:id="@+id/btn1"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_weight="1"
  android:text="增大透明度"
  android:layout_marginLeft="60dp"/>
 <Button
  android:id="@+id/btn2"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_weight="1"
  android:text="降低透明度" />
 <Button
  android:id="@+id/btn3"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_weight="1"
  android:layout_marginRight="60dp"
  android:text="下一张" />
 </LinearLayout>
 <ImageView
 android:id="@+id/image1"
 android:layout_width="400dp"
 android:layout_height="280dp"
 android:layout_gravity="center"
 android:src="@drawable/zm1"
 android:scaleType="fitCenter"/>
 <ImageView
 android:id="@+id/image2"
 android:layout_width="120dp"
 android:layout_height="120dp"
 android:background="#f0f"
 android:layout_margin="10dp"/>


</LinearLayout>

在MainActivity.java中:

package com.example.test02;

import androidx.appcompat.app.AppCompatActivity;

import android.graphics.Bitmap;
import android.graphics.drawable.BitmapDrawable;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;

public class MainActivity extends AppCompatActivity {
// 定义访问图片的数组
 private int[] images=new int[]{R.drawable.zm1,R.drawable.zm2,R.drawable.zm6,
  R.drawable.zm4,R.drawable.zm5};
// 定义默认显示的图片
 private int current=2;
// 定义图片的初始透明度
 private int alpha=255;
 private Button btn1,btn2,btn3;
 private ImageView image1,image2;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 btn1=findViewById(R.id.btn1);
 btn2=findViewById(R.id.btn2);
 btn3=findViewById(R.id.btn3);
 image1=findViewById(R.id.image1);
 image2=findViewById(R.id.image2);
 //定义查看下一张图片的监听器
 btn3.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
  image1.setImageResource(images[++current%images.length]);
  }
 });
// 为按钮添加监听器
 btn1.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
  //定义改变图片透明度的方法
  if (v==btn1){
   alpha+=20;
  }
  if (alpha>=255){
   alpha=255;
  }
  if (alpha<=0){
   alpha=0;
  }
  //改变图片的透明度
  image1.setImageAlpha(alpha);
  }
 });
 btn2.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
  if (v==btn2){
   alpha-=20;
  }
  if (alpha>=255){
   alpha=255;
  }
  if (alpha<=0){
   alpha=0;
  }
  image1.setImageAlpha(alpha);
  }
 });
 image1.setOnTouchListener(new View.OnTouchListener() {
  @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();
//  获取需要显示图片的开始点
  long x=Math.round(event.getX()*scale);
  long y=Math.round(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,(int)x,(int)y,120,120));
  image2.setImageAlpha(alpha);
  return false;
  }
 });


 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android开发使用RecyclerView添加点击事件实例详解

    Android开发使用RecyclerView添加点击事件实例详解

    这篇文章主要为大家介绍了Android开发使用RecyclerView添加点击事件实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • 快速解决fragment中onActivityResult不调用的问题

    快速解决fragment中onActivityResult不调用的问题

    下面小编就为大家带来一篇快速解决fragment中onActivityResult不调用的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • Android自定义View实现支付宝咻一咻效果

    Android自定义View实现支付宝咻一咻效果

    这篇文章主要为大家详细介绍了Android自定义View实现支付宝咻一咻效果的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • Android开心消消乐代码实例详解

    Android开心消消乐代码实例详解

    这篇文章主要介绍了Android开心消消乐代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • Android入门之PopupWindow用法实例解析

    Android入门之PopupWindow用法实例解析

    这篇文章主要介绍了Android入门之PopupWindow用法,对于Android初学者来说有一定的学习借鉴价值,需要的朋友可以参考下
    2014-08-08
  • android 字体颜色选择器(ColorPicker)介绍

    android 字体颜色选择器(ColorPicker)介绍

    本文将详细介绍android 字体颜色选择器(ColorPicker)需要了解更多的朋友可以参考下
    2012-11-11
  • 源码分析Android rinflate的使用

    源码分析Android rinflate的使用

    这篇文章主要将从源码的角度带大家一起分析Android rinflate的使用,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的可以了解一下
    2023-04-04
  • 自己实现Android View布局流程

    自己实现Android View布局流程

    这篇文章主要介绍了自己实现Android View布局流程,帮助大家更好的理解和学习使用Android,感兴趣的朋友可以了解下
    2021-03-03
  • android图像绘制(三)画布刷屏问题记录

    android图像绘制(三)画布刷屏问题记录

    在canvas中绘制动态图的时候,如果使用了一个固定的背景图片,只有一个小小的精灵在移动!这样的情况下却不得不在没帧中重新绘制背景图片,使得效率降低,本文章只是记录一下,并不是解决方法感兴趣的朋友可以了解下
    2013-01-01
  • Android实现原生锁屏页面音乐控制

    Android实现原生锁屏页面音乐控制

    这篇文章主要介绍了Android实现原生锁屏页面音乐控制,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12

最新评论