ScreenUtils

本文介绍了一个用于Android应用的屏幕尺寸工具类,该工具类提供了一系列方法来帮助开发者获取设备的屏幕尺寸信息,并提供了DP到PX及反之的转换方法。此外,还提供了针对不同屏幕尺寸的适配方法以及获取状态栏和虚拟按键高度的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class ScreenUtils {

    //屏幕宽度
    private static int mScreenW;
    //屏幕高度
    private static int mScreenH;
    //密度
    private static float mDensity;

    /**
     * 使用前必须初始化一下
     *
     * @param activity
     */

    public static void init(Activity activity) {
        WindowManager wm = activity.getWindowManager();
        Display display = wm.getDefaultDisplay();
        mScreenW = display.getWidth() < display.getHeight() ? display.getWidth() : display.getHeight();
        mScreenH = display.getWidth() > display.getHeight() ? display.getWidth() : display.getHeight();
        mDensity = activity.getResources().getDisplayMetrics().density;
    }

    /**
     * 获取屏幕宽度
     *
     * @return
     */

    public static int getScreenW() {
        return mScreenW;
    }

    /**
     * 获取屏幕高度
     *
     * @return
     */

    public static int getScreenH() {
        return mScreenH;
    }

    /**
     * 根据手机的分辨率从 dp 的单位 转成为 px(像素)
     *
     * @param dpValue
     * @return
     */

    public static int dip2px(float dpValue) {
        return (int) (dpValue * mDensity + 0.5f);
    }

    /**
     * 根据手机的分辨率从 px(像素) 的单位 转成为 dp
     *
     * @param pxValue
     * @return
     */

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

    /**
     * 根据720px的屏幕进行转化
     *
     * @param pxValue
     * @return
     */

    public static int px720dip(float pxValue) {
        int result = (int) (pxValue * mScreenW / 720);
        return result;
    }

    /**
     * 根据1080px的屏幕进行转化
     *
     * @param pxValue
     * @return
     */

    public static int px1080dip(float pxValue) {
        int result = (int) (pxValue * mScreenW / 1080);
        return result;
    }

    /**
     * 获取顶部标题栏的高度
     *
     * @param context
     * @return
     */

    private int getStatusBarHeight(Context context) {
        Class<?> c = null;
        Object obj = null;
        Field field = null;
        int x = 0, sbar = 0;
        try {
            c = Class.forName("com.android.internal.R$dimen");
            obj = c.newInstance();
            field = c.getField("status_bar_height");
            x = Integer.parseInt(field.get(obj).toString());
            sbar = context.getResources().getDimensionPixelSize(x);
        } catch (Exception e1) {
            e1.printStackTrace();
        }
        return sbar;
    }

    /**
     * 获取华为虚拟功能键高度
     *
     * @param context
     * @return
     */

    public static int getVirtualBarHeigh(Context context) {
        int vh = 0;
        WindowManager windowManager = (WindowManager) context.getSystemService(Context.WINDOW_SERVICE);
        Display display = windowManager.getDefaultDisplay();
        DisplayMetrics dm = new DisplayMetrics();
        try {
            @SuppressWarnings("rawtypes")
            Class c = Class.forName("android.view.Display");
            @SuppressWarnings("unchecked")
            Method method = c.getMethod("getRealMetrics", DisplayMetrics.class);
            method.invoke(display, dm);
            vh = dm.heightPixels - windowManager.getDefaultDisplay().getHeight();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return vh;
    }

}
override fun onCreating(savedInstanceState: Bundle?) { ensureSetNativeContentView() super.onCreating(savedInstanceState) // 开启数据流监听 CommunicateDelegate.get(this).open() // 添加前后台监听 AppUtils.registerAppStatusChangedListener(this) // 设置全屏模式和滑动显示状态栏 setupFullScreenMode() // 初始化界面 if (hasImageTrans && enableExternalPlayer) { // 有图传设备,且使用外部播放器的情况下,才使用悬浮窗 setBackground(null) // 界面嵌入悬浮窗中 uiDelegates.forEach { jobWindows.add(JobWindow(it)) } jobWindows.forEach { it.show() } // 跳转外部播放器 AppUtils.launchApp(Constants.siYiPkg) } else { // 直接嵌入Fragment } println("初始化播放器-----") uiDelegates.forEach { it.onAttach(binding.root) } // 初始化FPVue播放器 // initVuePlayer() // 播放图传推流 playStream(binding.videoPlayer,"rtsp://192.168.144.2:8554/main.264") playStream(binding.videoPlayer2,"rtsp://192.168.144.5:8554/main.264") } /** * 播放图传推流 * @param playView 播放器 */ private fun playStream(playView: StandardGSYVideoPlayer, url: String) { // 改变高度 timerTask { binding.thumb.layoutParams.height = ScreenUtils.getScreenHeight() + UtilX.getStatusBarHeight() * 2 binding.root.layoutParams.height = ScreenUtils.getScreenHeight() playView.thumbImageView = binding.thumb playView.setVideoAllCallBack(object : GSYSampleCallBack() { override fun onPrepared(url: String?, vararg objects: Any?) { super.onPrepared(url, *objects) findViewById<View>(R.id.thumb).visibility = View.GONE } }) playView.setUp(url, true, "Video") playView.setIsTouchWiget(false) playView.setIsTouchWigetFull(false) playView.setBottomProgressBarDrawable(null) // 有图传设备才播放 // if (hasImageTrans) playView.startPlayLogic() } }修改代码,使视频可以同时播放2个,现在只能播放1个,另一个视频会暂停
最新发布
05-30
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值