Android屏幕的大小、密度以及字符缩放比例——DisplayMetrics类

标签: android 屏幕 大小 | 发表时间:2012-06-17 10:14 | 作者:t80t90s
出处:http://blog.csdn.net

上一贴 对DisplayMetrics表述的还不是太透彻,这一贴专门来研究一下:


DisplayMetrics类  ——结构化的描述显示器的一般信息,包括它的大小、密度以及字符缩放比例。

 public float density;//屏幕像素密度值,density值表示每英寸有多少个显示点,与分辨率是两个不同的概念。

Android主要有以下几种屏:

QVGA和WQVGA屏density=120;

HVGA屏density=160;

WVGA屏density=240;

下面以480dip*800dip的WVGA(density=240)为例,详细列出不同density下屏幕分辨率信息:

当density=120时 屏幕实际分辨率为240px*400px (两个点对应一个分辨率)
状态栏和标题栏高各19px或者25dip
横屏是屏幕宽度400px 或者800dip,工作区域高度211px或者480dip
竖屏时屏幕宽度240px或者480dip,工作区域高度381px或者775dip

density=160时 屏幕实际分辨率为320px*533px (3个点对应两个分辨率)
状态栏和标题栏高个25px或者25dip
横屏是屏幕宽度533px 或者800dip,工作区域高度295px或者480dip
竖屏时屏幕宽度320px或者480dip,工作区域高度508px或者775dip

density=240时 屏幕实际分辨率为480px*800px (一个点对于一个分辨率)
状态栏和标题栏高个38px或者25dip
横屏是屏幕宽度800px 或者800dip,工作区域高度442px或者480dip
竖屏时屏幕宽度480px或者480dip,工作区域高度762px或者775dip

apk的资源包中,当屏幕density=240时使用hdpi标签的资源
当屏幕density=160时,使用mdpi标签的资源
当屏幕density=120时,使用ldpi标签的资源。
不加任何标签的资源是各种分辨率情况下共用的。
建议:布局时尽量使用单位dip,少使用px。

device independent pixels(设备独立像素). 不同设备有不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA、HVGA和QVGA 推荐使用这个,不依赖像素。

import android.content.Context;
import android.util.DisplayMetrics;


//计算公式 pixels = dips * (density / 160)

public class DensityUtil {
   
    private static final String TAG = DensityUtil.class.getSimpleName();
   
    // 当前屏幕的densityDpi
    private static float dmDensityDpi = 0.0f;
    private static DisplayMetrics dm;
    private static float scale = 0.0f;

   
    public DensityUtil(Context context) {
        // 获取当前屏幕
        dm = new DisplayMetrics();

        //返回当前资源对象的DispatchMetrics信息。
        dm = context.getApplicationContext().getResources().getDisplayMetrics();
        // 设置DensityDpi
        setDmDensityDpi(dm.densityDpi);
        // 密度因子
        scale = getDmDensityDpi() / 160;//等于 scale=dm.density;
        Logger.i(TAG, toString());
    }

   
    public static float getDmDensityDpi() {
        return dmDensityDpi;
    }

   
    public static void setDmDensityDpi(float dmDensityDpi) {
        DensityUtil.dmDensityDpi = dmDensityDpi;
    }

   
    public static int dip2px(float dipValue) {

        return (int) (dipValue * scale + 0.5f);

    }

   
    public int px2dip(float pxValue) {
        return (int) (pxValue / scale + 0.5f);
    }

    @Override
    public String toString() {
        return " dmDensityDpi:" + dmDensityDpi;
    }
}

其它的:

//dip转像素
 public static int DipToPixels(Context context,int dip) {
  final float SCALE = context.getResources().getDisplayMetrics().density;
  float valueDips =  dip;
  int valuePixels = (int)(valueDips * SCALE + 0.5f); 
  return valuePixels;

 }


 //像素转dip
 public static float PixelsToDip(Context context,int Pixels) {
  final float SCALE = context.getResources().getDisplayMetrics().density;
  float dips =Pixels / SCALE ;
  return dips;

 }

//指定图片长宽生成新图片

public static Bitmap decodeBitmap(Bitmap initialBitmap, int height, int weight) {
        int bmpHeight = initialBitmap.getHeight();
        int bmpWeight = initialBitmap.getWidth();
        float scale = Math.min(height / bmpHeight, weight / bmpWeight);
        Bitmap mutableBitmap = Bitmap.createScaledBitmap(initialBitmap, (int) (bmpWeight * scale), (int) (bmpHeight * scale), true);//指定图片长宽,生成新图片
        return mutableBitmap;
    }

//将Bitmap另存为指定的JPG文件   

public static void writePhotoJpg(Bitmap data, String pathName) {
        File file = new File(pathName);
        try {
            file.createNewFile();
            // BufferedOutputStream os = new BufferedOutputStream(
            // new FileOutputStream(file));

            FileOutputStream os = new FileOutputStream(file);
            data.compress(Bitmap.CompressFormat.JPEG, 100, os);
            os.flush();
            os.close();
            MyDebug.i("writePhotoJpg");

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
//将Bitmap另存为指定的PNG文件   
    public static void writePhotoPng(Bitmap data, String pathName) {
        File file = new File(pathName);
        try {
            file.createNewFile();
            FileOutputStream os = new FileOutputStream(file);
            // BufferedOutputStream os = new BufferedOutputStream(
            // new FileOutputStream(file));
            data.compress(Bitmap.CompressFormat.PNG, 100, os);
            os.flush();
            os.close();
            MyDebug.i("writePhotoPng");

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

作者:t80t90s 发表于2012-6-17 10:14:39 原文链接
阅读:0 评论:0 查看评论

相关 [android 屏幕 大小] 推荐:

Android屏幕大小适配问题解决

- - CSDN博客移动开发推荐文章
1、长度(真实长度):英寸、inch. 2、分辨率:density 每英寸像素数  dpi(密度). 4、dip的公式:px /dip=dpi/160  所以 dip 类似于英寸、长度(dp=dip,sp类似于dip)  dip=160*inch. 当dip一定时,dpi 越大,px就越大. 5、广义分辨率=长px*宽px.

Android屏幕的大小、密度以及字符缩放比例——DisplayMetrics类

- - CSDN博客推荐文章
上一贴 对DisplayMetrics表述的还不是太透彻,这一贴专门来研究一下:. DisplayMetrics类  ——结构化的描述显示器的一般信息,包括它的大小、密度以及字符缩放比例.  public float density;//屏幕像素密度值,density值表示每英寸有多少个显示点,与分辨率是两个不同的概念.

android截取屏幕图片

- - BlogJava-首页技术区
                mButton.setText("截屏次数:"+mPrintNum);.         //1.构建Bitmap   .         //2.获取屏幕   .         //3.保存Bitmap    .             //文件   .                 Toast.makeText(this, "截屏文件已保存至SDCard/PrintScreenDemo/ScreenImage/下", Toast.LENGTH_LONG).show();   .

android 屏幕适配原则

- - CSDN博客推荐文章
      Android手机屏幕大小不一,有480x320,640x360,800x480.怎样才能让App自动适应不同的屏幕呢. 其实很简单,只需要在res目录下创建不同的layout文件夹,比如:layout-640x360,layout-800x480,所有的layout文件在编译之后都会写入R.java里,而系统会根据屏幕的大小自己选择合适的layout进行使用.

关于Android的多种屏幕适配

- 甜菜 - 互联网的那点事...
严格来说,作为读者,你应该带着批判性质的眼光来看这篇文章,因为这篇文章是一个尚未通读Android官方开发资料《Supporting Multiple Screens》的纯产品人员所写,相关理解来源于零星的资料、实践以及和开发人员的沟通,此文章更多为目前盆地个人理解的总结. 我会给自己定下目标,早日通读官方资料,此文中的相关错误,也请予以指正.

Android的屏幕多样性支持

- - CSDN博客推荐文章
原文地址: http://developer.android.com/guide/practices/screens_support.html. 原文版权: Creative Commons 2.5 Attribution License. 译文作者:Jianan - [email protected].

android屏幕监控上下左右滑动

- - CSDN博客推荐文章
简单写一下,view 或者 activity 实现 OnGestureListener 接口. 在 onFling方法中实现左右滑动:. 在 onScroll 方法中实现上下滑动:. 作者:spider_zhcl 发表于2012-6-10 12:33:34 原文链接. 阅读:12 评论:0 查看评论.

android中dip、dp、px、sp和屏幕密度

- - 编程语言 - ITeye博客
dip: device independent pixels(设备独立像素). 不同设备有不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA、HVGA和QVGA 推荐使用这    这个,不依赖像素.     这里要特别注意dip与屏幕密度有关,而屏幕密度又与具体的硬件有关,硬件设置不正确,有可能导致dip不能正常显示.

Android三屏幕可折叠概念手机 手机中的变形金刚

- 洞箫 - cnBeta.COM
大家想知道未来的手机是怎么样的呢,今天我们为大家带来的是一款三屏幕概念手机,顾名思义所谓三屏幕就是有三块手机屏幕. 作为这款手机的亮点三屏幕能给你带来视觉上的最大化满足,不信你自己看.

Panasonic FX90 触控屏幕外,还支持 WiFi 传送至 Android 及 iPhone App

- Mr.aa - Engadget 中国版
对很多喜欢摄影的人来说,相机内置 WiFi 是一个很吸引人的功能,只是想到当中复杂的设定程序及有限制的功能,便令人泄气. Panasonic 看到这个缺点,便推出支持 Android 及 iPhone App 的 Lumix FX90,能够通过 WiFi 把相片传送到手机 App 上,然后传送到云端的 Lumix Club 或 Twitter、Facebook 或 YouTube 等等.