• android获取屏幕宽高与获取控件宽高


    获取屏幕宽高

    [java] view plaincopy
     
    1. // 获取屏幕宽高(方法1)  
    2. int screenWidth = getWindowManager().getDefaultDisplay().getWidth(); // 屏幕宽(像素,如:480px)  
    3. int screenHeight = getWindowManager().getDefaultDisplay().getHeight(); // 屏幕高(像素,如:800p)  
    4. Log.e(TAG + " getDefaultDisplay", "screenWidth=" + screenWidth + "; screenHeight=" + screenHeight);  
    5. // 获取屏幕密度(方法2)  
    6. DisplayMetrics dm = new DisplayMetrics();  
    7. dm = getResources().getDisplayMetrics();  
    8. float density = dm.density; // 屏幕密度(像素比例:0.75/1.0/1.5/2.0)  
    9. int densityDPI = dm.densityDpi; // 屏幕密度(每寸像素:120/160/240/320)  
    10. float xdpi = dm.xdpi;  
    11. float ydpi = dm.ydpi;  
    12. Log.e(TAG + " DisplayMetrics", "xdpi=" + xdpi + "; ydpi=" + ydpi);  
    13. Log.e(TAG + " DisplayMetrics", "density=" + density + "; densityDPI=" + densityDPI);  
    14. screenWidth = dm.widthPixels; // 屏幕宽(像素,如:480px)  
    15. screenHeight = dm.heightPixels; // 屏幕高(像素,如:800px)  
    16. Log.e(TAG + " DisplayMetrics(111)", "screenWidth=" + screenWidth + "; screenHeight=" + screenHeight);  
    17. // 获取屏幕密度(方法3)  
    18. dm = new DisplayMetrics();  
    19. getWindowManager().getDefaultDisplay().getMetrics(dm);  
    20. density = dm.density; // 屏幕密度(像素比例:0.75/1.0/1.5/2.0)  
    21. densityDPI = dm.densityDpi; // 屏幕密度(每寸像素:120/160/240/320)  
    22. xdpi = dm.xdpi;  
    23. ydpi = dm.ydpi;  
    24. Log.e(TAG + " DisplayMetrics", "xdpi=" + xdpi + "; ydpi=" + ydpi);  
    25. Log.e(TAG + " DisplayMetrics", "density=" + density + "; densityDPI=" + densityDPI);  
    26. int screenWidthDip = dm.widthPixels; // 屏幕宽(dip,如:320dip)  
    27. int screenHeightDip = dm.heightPixels; // 屏幕宽(dip,如:533dip)  
    28. Log.e(TAG + " DisplayMetrics(222)", "screenWidthDip=" + screenWidthDip + "; screenHeightDip=" + screenHeightDip);  
    29. screenWidth = (int)(dm.widthPixels * density + 0.5f); // 屏幕宽(px,如:480px)  
    30. screenHeight = (int)(dm.heightPixels * density + 0.5f); // 屏幕高(px,如:800px)  
    31. Log.e(TAG + " DisplayMetrics(222)", "screenWidth=" + screenWidth + "; screenHeight=" + screenHeight);   

    获取控件的宽高,一般来说,我们在onCreate里面得到的控件的宽高全是0.采用下面的方法,可以得到真实的宽高

    [csharp] view plaincopy
     
    1.         //------------------------------------------------方法一  
    2.         int w = View.MeasureSpec.makeMeasureSpec(0,View.MeasureSpec.UNSPECIFIED);  
    3.         int h = View.MeasureSpec.makeMeasureSpec(0,View.MeasureSpec.UNSPECIFIED);  
    4.         imageView.measure(w, h);  
    5.         int height =imageView.getMeasuredHeight();  
    6.         int width =imageView.getMeasuredWidth();  
    7.         textView.append(" "+height+","+width);  
    8.           
    9.     此方法会加载onMeasure三次  
    10.           
    11.           
    12.   
    13.         //-----------------------------------------------方法二  
    14.         ViewTreeObserver vto = imageView.getViewTreeObserver();  
    15.         vto.addOnPreDrawListener(new ViewTreeObserver.OnPreDrawListener() {  
    16.             public boolean onPreDraw() {  
    17.                 int height = imageView.getMeasuredHeight();  
    18.                 int width = imageView.getMeasuredWidth();  
    19.                 textView.append(" "+height+","+width);  
    20.                 return true;  
    21.             }  
    22.         });  
    23.   
    24.     此方法会加载onMeasure二次,但是回调函数会回调很多次  
    25.   
    26.      //-----------------------------------------------方法三     
    27.         ViewTreeObserver vto2 = imageView.getViewTreeObserver();    
    28.         vto2.addOnGlobalLayoutListener(new OnGlobalLayoutListener() {  
    29.             @Override    
    30.             public void onGlobalLayout() {  
    31.                 imageView.getViewTreeObserver().removeGlobalOnLayoutListener(this);    
    32.                 textView.append(" "+imageView.getHeight()+","+imageView.getWidth());  
    33.             }    
    34.         });    
    35.   
    36.     <pre name="code" class="csharp">   此方法会加载onMeasure二次,但是回调函数只回调一次</pre><p></p>  
    37. <pre></pre>  
    38. <br>  
    39. <br>  
    40. <p></p>  
    41.       
    42.         <div style="padding-top:20px">           
    43.             <p style="font-size:12px;">版权声明:本文为博主原创文章,未经博主允许不得转载。</p>  
    44.         </div>  
  • 相关阅读:
    页面可视化搭建 整理
    单页面应用(SPA)重新部署后,正在浏览的页面如何更新缓存?
    vim 使用
    浏览器缓存 知识点
    http 2.0 新特性
    GoJS 在 vue 项目中的使用
    详解Vue中watch的高级用法
    什么是 PWA?
    代码风格统一工具:EditorConfig 和 静态代码检查工具:ESLint
    vue-cli 3.x 使用
  • 原文地址:https://www.cnblogs.com/zmc/p/4864271.html
Copyright © 2020-2023  润新知