欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android自定義控件ImageView實(shí)現(xiàn)點(diǎn)擊之后出現(xiàn)陰影效果

 更新時(shí)間:2017年12月12日 12:01:35   作者:zmybiealex  
這篇文章主要為大家詳細(xì)介紹了Android自定義控件ImageView實(shí)現(xiàn)點(diǎn)擊之后有陰影效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

今天美工 直接給我一張圖片,要我實(shí)現(xiàn)圖片點(diǎn)擊之后有陰影效果,當(dāng)時(shí)想到了ImageButton,隨即自己寫了個(gè)Demo,發(fā)現(xiàn)ImageButton繼承ImageView 會有一個(gè)默認(rèn)的背景樣式,而且在布局中設(shè)計(jì)src(前景) 太丑,于是自己寫了個(gè)自定義控件ImageView實(shí)現(xiàn)了點(diǎn)擊之后,點(diǎn)擊區(qū)域有一個(gè)灰色的陰影效果,如下:

添加監(jiān)聽回調(diào)等;

布局文件代碼:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout 
 xmlns:android="http://schemas.android.com/apk/res/android" 
 xmlns:tools="http://schemas.android.com/tools" 
 android:id="@+id/activity_main" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:paddingBottom="@dimen/activity_vertical_margin" 
 android:paddingLeft="@dimen/activity_horizontal_margin" 
 android:paddingRight="@dimen/activity_horizontal_margin" 
 android:paddingTop="@dimen/activity_vertical_margin" 
 tools:context="com.hanzheng.imagebutton.MainActivity" 
 android:orientation="vertical"> 
 
 
 <ImageButton 
  android:id="@+id/button" 
  android:layout_width="100dp" 
  android:layout_height="100dp" 
  android:src="#ff0000" 
  /> 
 
 
 <com.hanzheng.imagebutton.ClickImageView 
  android:layout_marginTop="10dp" 
  android:id="@+id/clickimageview" 
  android:clickable="true" 
  android:src="@drawable/flow" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content"/> 
 
 
 <com.hanzheng.imagebutton.ClickImageView 
  android:layout_marginTop="10dp" 
  android:id="@+id/clickimageview2" 
  android:clickable="true" 
  android:src="#0f0" 
  android:layout_width="100dp" 
  android:layout_height="100dp"/> 
</LinearLayout> 

注意: 自定義控件中使用的src屬性,使用background會失效

ImageView中xml屬性src和background的區(qū)別:

background會根據(jù)ImageView組件給定的長寬進(jìn)行拉伸,而src就存放的是原圖的大小,不會進(jìn)行拉伸。src是圖片內(nèi)容(前景),bg是背景,可以同時(shí)使用。

此外:scaleType只對src起作用;bg可設(shè)置透明度,比如在ImageButton中就可以用Android:scaleType控制圖片的縮放方式,控制的圖片為資源而不是背景,即android:src="@drawable/logo",而非android:background="@drawable/logo"程序中動態(tài)加載圖片也類似,如:應(yīng)該imgView.setImageResource(R.drawable.*);而非imgView.setBackgroundResource(R.drawable.*);

更詳細(xì)的scaleType說明:

CENTER /center 在視圖中心顯示圖片,并且不縮放圖片
CENTER_CROP / centerCrop 按比例縮放圖片,使得圖片長 (寬)的大于等于視圖的相應(yīng)維度
CENTER_INSIDE / centerInside 按比例縮放圖片,使得圖片長 (寬)的小于等于視圖的相應(yīng)維度
FIT_CENTER / fitCenter 按比例縮放圖片到視圖的最小邊,居中顯示
FIT_END / fitEnd 按比例縮放圖片到視圖的最小邊,顯示在視圖的下部分位置
FIT_START / fitStart 把圖片按比例擴(kuò)大/縮小到視圖的最小邊,顯示在視圖的上部分位置
FIT_XY / fitXY 把圖片不按比例縮放到視圖的大小顯示
MATRIX / matrix 用矩陣來繪制

自定義控件ClickImageView的代碼:

package com.hanzheng.imagebutton; 
 
import android.content.Context; 
import android.util.AttributeSet; 
import android.view.MotionEvent; 
import android.widget.ImageView; 
 
/** 
 * Created by zmybi on 2017/1/3. 
 */ 
 
public class ClickImageView extends ImageView { 
 
 public ClickImageView(Context context) { 
  super(context); 
 } 
 public ClickImageView(Context context, AttributeSet attrs) { 
  super(context, attrs); 
 } 
 public ClickImageView(Context context, AttributeSet attrs, int defStyleAttr) { 
  super(context, attrs, defStyleAttr); 
 } 
 
 
 @Override 
 public boolean onTouchEvent(MotionEvent event) { 
 
  switch (event.getAction()) { 
   case MotionEvent.ACTION_DOWN: 
    this.setColorFilter(0x33000000); 
    //重寫觸摸事件的方法,當(dāng)按鈕被點(diǎn)擊的時(shí)候 
    mOnClickListener.onClick(); 
    return true; 
   case MotionEvent.ACTION_UP: 
   case MotionEvent.ACTION_CANCEL: 
    this.setColorFilter(null); 
    break; 
  } 
  return super.onTouchEvent(event); 
 } 
 
 /** 
  * 定義點(diǎn)擊的接口 
  */ 
 interface OnClickListener { 
  void onClick(); 
 } 
 
 private OnClickListener mOnClickListener; 
 
 public void setOnClickListener (OnClickListener onClickListener) { 
  this.mOnClickListener = onClickListener; 
 } 
 
 
} 

MainActivity中的代碼:一個(gè)監(jiān)聽回調(diào)

package com.hanzheng.imagebutton; 
 
import android.os.Bundle; 
import android.support.v7.app.AppCompatActivity; 
import android.view.View; 
import android.widget.ImageButton; 
import android.widget.Toast; 
 
public class MainActivity extends AppCompatActivity { 
 
 private ImageButton mBt; 
 private ClickImageView mCiv; 
 private ClickImageView mCiv2; 
 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.activity_main); 
  mBt = (ImageButton) findViewById(R.id.button); 
  mCiv = (ClickImageView) findViewById(R.id.clickimageview); 
  mCiv2 = (ClickImageView) findViewById(R.id.clickimageview2); 
  mCiv.setOnClickListener(new ClickImageView.OnClickListener() { 
   @Override 
   public void onClick() { 
    Toast.makeText(MainActivity.this,"自定義ImageView點(diǎn)擊1",Toast.LENGTH_SHORT).show(); 
   } 
  }); 
 
  mCiv2.setOnClickListener(new ClickImageView.OnClickListener() { 
   @Override 
   public void onClick() { 
    Toast.makeText(MainActivity.this,"自定義ImageView點(diǎn)擊2",Toast.LENGTH_SHORT).show(); 
   } 
  }); 
 
  mBt.setOnClickListener(new View.OnClickListener() { 
   @Override 
   public void onClick(View view) { 
    Toast.makeText(MainActivity.this,"ImageButton點(diǎn)擊",Toast.LENGTH_SHORT).show(); 
   } 
  }); 
 } 
} 

至此,一個(gè)自定義的ImageView實(shí)現(xiàn)點(diǎn)擊陰影完成。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • flutter優(yōu)雅實(shí)現(xiàn)掃碼槍獲取數(shù)據(jù)源示例詳解

    flutter優(yōu)雅實(shí)現(xiàn)掃碼槍獲取數(shù)據(jù)源示例詳解

    這篇文章主要為大家介紹了flutter優(yōu)雅實(shí)現(xiàn)掃碼槍獲取數(shù)據(jù)源示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • Android 優(yōu)化之a(chǎn)pp啟動優(yōu)化的實(shí)現(xiàn)

    Android 優(yōu)化之a(chǎn)pp啟動優(yōu)化的實(shí)現(xiàn)

    這篇文章主要介紹了Android 優(yōu)化之啟動優(yōu)化的實(shí)現(xiàn),啟動分為冷啟動和熱啟動,溫啟動,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-07-07
  • Android ScrollView的頂部下拉和底部上拉回彈效果

    Android ScrollView的頂部下拉和底部上拉回彈效果

    本篇文章主要介紹了Android ScrollView的頂部下拉和底部上拉回彈效果,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05
  • Android開發(fā)之ScrollView的滑動監(jiān)聽

    Android開發(fā)之ScrollView的滑動監(jiān)聽

    這篇文章主要介紹了Android開發(fā)之ScrollView的滑動監(jiān)聽,非常不錯,介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-08-08
  • Android編程實(shí)現(xiàn)的微信支付功能詳解【附Demo源碼下載】

    Android編程實(shí)現(xiàn)的微信支付功能詳解【附Demo源碼下載】

    這篇文章主要介紹了Android編程實(shí)現(xiàn)的微信支付功能,結(jié)合實(shí)例形式詳細(xì)分析了Android微信支付功能的實(shí)現(xiàn)步驟與具體操作技巧,并附帶了Demo源碼供讀者下載參考,需要的朋友可以參考下
    2017-07-07
  • Android編程實(shí)現(xiàn)播放視頻的方法示例

    Android編程實(shí)現(xiàn)播放視頻的方法示例

    這篇文章主要介紹了Android編程實(shí)現(xiàn)播放視頻的方法,結(jié)合具體實(shí)例形式分析了Android使用VideoView類播放視頻的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2017-08-08
  • 如何在原有Android項(xiàng)目中快速集成React Native詳解

    如何在原有Android項(xiàng)目中快速集成React Native詳解

    創(chuàng)建一個(gè)React Native項(xiàng)目并寫一個(gè)純的 React Native 應(yīng)用可以參考官方指南。下面這篇文章主要給大家介紹了關(guān)于如何在原有Android項(xiàng)目中快速集成React Native的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。
    2017-12-12
  • Flutter?DateTime日期轉(zhuǎn)換的詳細(xì)使用

    Flutter?DateTime日期轉(zhuǎn)換的詳細(xì)使用

    本文主要介紹了Flutter?DateTime日期轉(zhuǎn)換的詳細(xì)使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • Android 動態(tài)改變布局實(shí)例詳解

    Android 動態(tài)改變布局實(shí)例詳解

    這篇文章主要介紹了Android 動態(tài)改變布局實(shí)例詳解的相關(guān)資料,這里舉例說明如何實(shí)現(xiàn)動態(tài)改變布局的例子,幫助大家學(xué)習(xí)理解,需要的朋友可以參考下
    2016-11-11
  • Android筆記整理之常見錯誤及解決方案匯總

    Android筆記整理之常見錯誤及解決方案匯總

    本文是小編日常整理的筆記關(guān)于android常見的錯誤及解決方案,本文對大家學(xué)習(xí)android相關(guān)知識非常有幫助,遇到問題能夠很好的定位問題解決問題,感興趣的朋友了解了解吧
    2015-11-11

最新評論