65Popupwindow的美化&&屏幕适配&&像素转dp的工具类的写法

本文介绍了一种使用资源图片指定布局美化Android应用中弹出窗体的方法,并提供了具体的XML布局代码示例。同时,文章还讲解了如何通过DensityUtil工具类实现不同屏幕尺寸上的适配,确保弹出窗体在不同设备上都能正确显示。

使用资源图片指定的布局来美化弹出窗体:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    android:background="@drawable/local_popup_bg"
     >
     
    <LinearLayout 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        >
        <ImageView 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/img1"
            />
        <TextView 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="卸载"
            />
        
    </LinearLayout>
     <LinearLayout 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        >
        <ImageView 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/img2"
            />
        <TextView 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="启动"
            />
        
    </LinearLayout>
     <LinearLayout 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        >
        <ImageView 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/img3"
            />
        <TextView 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="分享"
            />
        
    </LinearLayout>
    

</LinearLayout>
代码中加载view:

View contentView = View.inflate(getApplicationContext(), R.layout.popup_app_item, null);

运行:


现在这个弹出窗体距离左边太近了,得让他距离左边的距离远一点,在代码中指定的大小单位均为像素,我们需要使用dip,这样才能适配各种各样的屏幕

package com.ustc.mobilemanager.utils;

import android.content.Context;

public class DensityUtil {
	  /** 
     * 根据手机的分辨率从 dip 的单位 转成为 px(像素) 
     */  
    public static int dip2px(Context context, float dpValue) {  
        final float scale = context.getResources().getDisplayMetrics().density;  
        return (int) (dpValue * scale + 0.5f);  
    }  
  
    /** 
     * 根据手机的分辨率从 px(像素) 的单位 转成为 dp 
     */  
    public static int px2dip(Context context, float pxValue) {  
        final float scale = context.getResources().getDisplayMetrics().density;  
        return (int) (pxValue / scale + 0.5f);  
    } 
}


调用:

				int dip = 60;
				
				int px = DensityUtil.dip2px(getApplicationContext(), dip);
				
				
				popupWindow.showAtLocation(parent, Gravity.LEFT | Gravity.TOP, px, location[1]);
				







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值