Android 圖片切換器(dp、sp、px) 的單位轉(zhuǎn)換器
Android 圖片切換器
這幾天一直在整理組件想留著以后使用.還是一點(diǎn)一點(diǎn)整理吧.今天把上周整理的 ImageSwitcher 和單位轉(zhuǎn)換器(dp/sp/px).
下面上內(nèi)容
ImageSwitcher:
圖像查看器,好像是老組件了,今天先更一個(gè)基礎(chǔ)的組件,后期如果有時(shí)間繼續(xù)擴(kuò)展.
那么圖像查看器,就是和 Windows 系統(tǒng)下的圖片查看器比較類(lèi)似.自帶上一張和下一張的功能.
這個(gè)組件有以下幾個(gè)特點(diǎn),本人感覺(jué):
1.該組件屬于容器性質(zhì);
2.ImageSwitcher 本身繼承了 FrameLayout, 也可以使用幀布局的一些屬性.
3.在使用 ImageSwitcher 的時(shí)候,必須實(shí)現(xiàn) ViewSwitcher.ViewFactory 的接口,然后通過(guò)復(fù)寫(xiě) makeView() 方法來(lái)創(chuàng)建用于顯示圖片的 ImageView,并且 makeView()方法返回一個(gè)顯示圖片的 ImageView.
4.圖片加載 ImageView 上的話,如果是本地資源的話,需要使用 setImageResource() 方法.
上面基本的原理大致描述清楚,下面上代碼
XML 布局文件,這里面只有2個(gè)按鈕和 ImageSwitcher 的組件
<?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/layout" android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center" android:orientation="horizontal"> <Button android:id="@+id/up_btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="上一張" /> <!-- 圖像轉(zhuǎn)換器--> <ImageSwitcher android:id="@+id/main_imageswitcher" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" /> <Button android:id="@+id/down_btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="下一張" /> </LinearLayout>
Java 代碼
public class MainActivity extends AppCompatActivity { //聲明并初始化一個(gè)保存顯示圖像id的數(shù)組 private int[] imageId = new int[]{R.mipmap.weathericon_graph_01, R.mipmap.weathericon_graph_02, R.mipmap.weathericon_graph_03, R.mipmap.weathericon_graph_04, R.mipmap.weathericon_graph_05}; //當(dāng)前顯示圖像的索引 private int index; //聲明一個(gè)圖像切換器對(duì)象; private ImageSwitcher imageSwitcher; private ImageView imageView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); //給圖像器所有圖像設(shè)置動(dòng)畫(huà)效果 //淡入動(dòng)畫(huà) imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_in)); //淡出動(dòng)畫(huà) imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_out)); //設(shè)置 imageSwitcher 的視圖切換工廠,復(fù)寫(xiě) makeView() 方法 imageSwitcher.setFactory(new ViewSwitcher.ViewFactory() { @Override public View makeView() { imageView = new ImageView(MainActivity.this); //設(shè)置圖片的尺寸,如何與這個(gè)ImageView 相匹配. //@parms FIT_CENTER 保持居中并且縮放圖像. imageView.setScaleType(ImageView.ScaleType.FIT_CENTER); //設(shè)置 imageView的位置/大小屬性. /** * 進(jìn)行Dp 和px 之間的轉(zhuǎn)換*/ int widpx = DisplayUtils.dip2px(MainActivity.this, 200); int heipx = DisplayUtils.dip2px(MainActivity.this, 200); imageView.setLayoutParams(new ImageSwitcher.LayoutParams( widpx, heipx)); //返回 imageView 對(duì)象 return imageView; } }); //使 imageSwitcher 獲得顯示的圖片 imageSwitcher.setImageResource(imageId[index]); findViewById(R.id.up_btn).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (index > 0) { index--; } else { index = imageId.length - 1; } imageSwitcher.setImageResource(imageId[index]); } }); findViewById(R.id.down_btn).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (index < imageId.length - 1) { index++; } else { index = 0; } imageSwitcher.setImageResource(imageId[index]); } }); } private void initView() { imageSwitcher = (ImageSwitcher) findViewById(R.id.main_imageswitcher); }
在寫(xiě)這個(gè)類(lèi)的同時(shí),由于涉及到 DP<–>PX 之間,然后寫(xiě)了個(gè)工具類(lèi),下面是工具類(lèi)
package com.lanouteam.dllo.imageswitcherdemo; import android.content.Context; import android.util.TypedValue; import java.util.TreeSet; /** * Created by dllo on 16/4/4. * dp/sp 轉(zhuǎn)換為px 的工具類(lèi); * * */ public class DisplayUtils { /** * 將px值轉(zhuǎn)換為 dip 或者dp 值,保證尺寸大小不變. * * @param px Value * @param scale * (DisplayMetrics類(lèi)中屬性 density) * density 就是px 向 dp或sp的換算比例 * * @return * */ public static int px2dip(Context context,float pxValue){ final float scale =context.getResources().getDisplayMetrics().density; return (int) (pxValue/scale +0.5f); } /** * 將 px 值轉(zhuǎn)換為dp 或者 dip 值,保證尺寸大小不變 * @param dipValue * @param scale * (DisplayMetrics類(lèi)中屬性 density) * @return * */ public static int dip2px(Context context ,float dipValue){ final float scale =context.getResources().getDisplayMetrics().density; return (int) (dipValue*scale+0.5f); } /** * 將px 值轉(zhuǎn)換成 sp值,保證文字大小不變 * * @param pxValue * @param fontScale * (DisplayMetrics類(lèi)中屬性 density) * @return * */ public static int px2sp(Context context,float pxValue){ final float fontScale =context.getResources().getDisplayMetrics().density; return (int) ((pxValue/fontScale)+0.5f); } /** * 將 px 值轉(zhuǎn)換為dp 或者 dip 值,保證尺寸大小不變 * @param dipValue * @param scale * (DisplayMetrics類(lèi)中屬性 density) * @return * */ public static int sp2dip(Context context ,float spValue){ final float scale =context.getResources().getDisplayMetrics().density; return (int) (spValue*scale+0.5f); } /** * density 是dp 和sp 相對(duì)于px 的換算比例 * 而系統(tǒng)也提供了TypedValue 類(lèi)幫助轉(zhuǎn)換 * */ protected int dp2px(int dp,Context context){ //通過(guò)TypedValue工具類(lèi)來(lái)進(jìn)行轉(zhuǎn)換 return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP,dp,context.getResources().getDisplayMetrics()); } protected int sp2px(int sp,Context context){ return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_SP,sp,context.getResources().getDisplayMetrics()); } }
有了這個(gè)在 Java 代碼中,轉(zhuǎn)換代碼就比較方便了.
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
Android應(yīng)用開(kāi)發(fā)中自定義ViewGroup的究極攻略
這里我們要演示的自定義ViewGroup中將實(shí)現(xiàn)多種方式排列和滑動(dòng)等效果,并且涵蓋子View之間Touch Event的攔截與處理等問(wèn)題,完全干貨,下面就為大家送上Android應(yīng)用開(kāi)發(fā)中自定義ViewGroup的究極實(shí)例攻略2016-05-05Android自定義控件實(shí)現(xiàn)簡(jiǎn)單滑動(dòng)開(kāi)關(guān)效果
這篇文章主要為大家詳細(xì)介紹了Android自定義控件實(shí)現(xiàn)簡(jiǎn)單滑動(dòng)開(kāi)關(guān)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02基于fluttertoast實(shí)現(xiàn)封裝彈框提示工具類(lèi)
這篇文章主要為大家介紹了基于fluttertoast實(shí)現(xiàn)封裝彈框提示工具類(lèi)的實(shí)現(xiàn)代碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05Android組件Glide實(shí)現(xiàn)圖片平滑滾動(dòng)效果
這篇文章主要介紹了Android組件Glide實(shí)現(xiàn)圖片平滑滾動(dòng)效果的相關(guān)資料,具有一定的參考價(jià)值,需要的朋友可以參考下2016-07-07Android仿百度谷歌搜索自動(dòng)提示框AutoCompleteTextView簡(jiǎn)單應(yīng)用示例
這篇文章主要介紹了Android仿百度谷歌搜索自動(dòng)提示框AutoCompleteTextView簡(jiǎn)單應(yīng)用,結(jié)合實(shí)例形式分析了AutoCompleteTextView Widget使用步驟與相關(guān)操作技巧,需要的朋友可以參考下2016-10-10Android編程實(shí)現(xiàn)短信收發(fā)及語(yǔ)音播報(bào)提示功能示例
這篇文章主要介紹了Android編程實(shí)現(xiàn)短信收發(fā)及語(yǔ)音播報(bào)提示功能,結(jié)合實(shí)例形式分析了Android實(shí)現(xiàn)短信的接收、發(fā)送以及相應(yīng)的語(yǔ)音播報(bào)提示功能相關(guān)操作技巧,需要的朋友可以參考下2017-08-08