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)下的圖片查看器比較類似.自帶上一張和下一張的功能.
這個(gè)組件有以下幾個(gè)特點(diǎn),本人感覺:
1.該組件屬于容器性質(zhì);

2.ImageSwitcher 本身繼承了 FrameLayout, 也可以使用幀布局的一些屬性.
3.在使用 ImageSwitcher 的時(shí)候,必須實(shí)現(xiàn) ViewSwitcher.ViewFactory 的接口,然后通過復(fù)寫 makeView() 方法來創(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è)圖像切換器對象;
private ImageSwitcher imageSwitcher;
private ImageView imageView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
//給圖像器所有圖像設(shè)置動畫效果
//淡入動畫
imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_in));
//淡出動畫
imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_out));
//設(shè)置 imageSwitcher 的視圖切換工廠,復(fù)寫 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 對象
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);
}
在寫這個(gè)類的同時(shí),由于涉及到 DP<–>PX 之間,然后寫了個(gè)工具類,下面是工具類
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 的工具類;
*
*
*/
public class DisplayUtils {
/**
* 將px值轉(zhuǎn)換為 dip 或者dp 值,保證尺寸大小不變.
*
* @param px Value
* @param scale
* (DisplayMetrics類中屬性 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類中屬性 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類中屬性 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類中屬性 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 相對于px 的換算比例
* 而系統(tǒng)也提供了TypedValue 類幫助轉(zhuǎn)換
* */
protected int dp2px(int dp,Context context){
//通過TypedValue工具類來進(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)換代碼就比較方便了.
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
Android實(shí)現(xiàn)歌曲播放時(shí)歌詞同步顯示具體思路
歌曲播放時(shí)歌詞同步顯示,我們需要讀取以上歌詞文件的每一行轉(zhuǎn)換成成一個(gè)個(gè)歌詞實(shí)體,可根據(jù)當(dāng)前播放器的播放進(jìn)度與每句歌詞的開始時(shí)間,得到當(dāng)前屏幕中央高亮顯示的那句歌詞2013-06-06
使用CMake構(gòu)建OpenCV項(xiàng)目過程解析
這篇文章主要介紹了使用CMake構(gòu)建OpenCV項(xiàng)目過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
android獲取當(dāng)前接入點(diǎn)信息判斷是ctwap還是ctnet實(shí)例代碼
這篇文章主要介紹了android獲取當(dāng)前接入點(diǎn)信息判斷是ctwap還是ctnet的方法,大家參考使用吧2013-11-11
Android permission denied原因歸納和解決辦法
大家好,本篇文章主要講的是Android permission denied原因歸納和解決辦法,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下哦2021-12-12
Android 中使用EditText 點(diǎn)擊全選再次點(diǎn)擊取消全選功能
這篇文章主要介紹了Android 中使用EditText 點(diǎn)擊全選再次點(diǎn)擊取消全選功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2016-12-12
Android開發(fā)之Service用法實(shí)例
這篇文章主要介紹了Android開發(fā)之Service用法,實(shí)例分析了Android中Service的功能及使用技巧,需要的朋友可以參考下2015-05-05
Android使用多線程實(shí)現(xiàn)斷點(diǎn)下載
這篇文章主要介紹了Android使用多線程實(shí)現(xiàn)斷點(diǎn)下載,多線程下載是加快下載速度的一種方式,感興趣的小伙伴們可以參考一下2016-03-03
Andriod Service與Thread的區(qū)別介紹
我們要明確Service是運(yùn)行在主線程的,不能有耗時(shí)操作,這樣,在Service中處理耗時(shí)操作的時(shí)候,我們依然需要使用線程來處理,既然在Service里也要創(chuàng)建一個(gè)子線程,那為什么不直接在Activity里創(chuàng)建呢,下面通過本文給大家介紹Andriod Service與Thread的區(qū)別,一起看看吧2017-04-04
Android斷點(diǎn)續(xù)傳下載器JarvisDownloader的示例
本篇文章主要介紹了Android斷點(diǎn)續(xù)傳下載器JarvisDownloader的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05

