Cordova 小米8留海屏幕适配之沉状态栏与 适配大屏幕手机 从开始到结束 总结

 之前项目中打包的apk安装到全面屏手机后,发现在应用下方出现了一大块黑色区域(如:小米8),只有在系统中设置适配全面屏才能让应用在全面屏手机中显示正常,但是这种方式并不友好,而且有些手机厂商可能也没有这种设置,所以还是需要我们再打包的时候就做一些相应的处理。

        
            
                
                
            
 
        
 
        

接下来就是沉浸状态栏了

没用cordova的小伙伴 直接style里面修改这个属性就可以了

 @drawable/start_page

完整的代码

    

也可在代码里面修改 setContentView下面

        setContentView(R.layout.activity_main);
        ConnectServer.Print("启动时间=====1" + System.currentTimeMillis());
        getWindow().setBackgroundDrawable(getResources().getDrawable(R.drawable.bg_view_tab));

Cordova 之燃烧我的卡路里  (删除 自己配置statusBar)

方案1删除()

https://blog.csdn.net/mp624183768/article/details/83578144

方案2 改颜色 ()

从网上找了一套方案 灵感来自 https://blog.csdn.net/h0422856/article/details/70820990?utm_source=itdadao&utm_medium=referral

然后给web端看了 就很上道的给了一串代码 换上了 居然真的可以了

在app.js下 修改

             if (window.StatusBar) {
                                     window.StatusBar.overlaysWebView(true);
                                     window.StatusBar.styleDefault();
                                     window.StatusBar.backgroundColorByName("gxbColor");
                                 }

在 cordova-plugin-statusbar

cordova.define("cordova-plugin-statusbar.statusbar", function(require, exports, module) {
/*
 *
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 *
*/

var exec = require('cordova/exec');

var namedColors = {
    "black": "#000000",
    "darkGray": "#A9A9A9",
    "lightGray": "#D3D3D3",
    "white": "#FFFFFF",
    "gray": "#808080",
    "red": "#FF0000",
    "green": "#00FF00",
    "blue": "#0000FF",
    "cyan": "#00FFFF",
    "yellow": "#FFFF00",
    "magenta": "#FF00FF",
    "orange": "#FFA500",
    "purple": "#800080",
    "brown": "#A52A2A",
     "gxbColor": "#1FB6FF"
};

var StatusBar = {

    isVisible: true,

    overlaysWebView: function (doOverlay) {
        exec(null, null, "StatusBar", "overlaysWebView", [doOverlay]);
    },

    styleDefault: function () {
        // dark text ( to be used on a light background )
        exec(null, null, "StatusBar", "styleDefault", []);
    },

    styleLightContent: function () {
        // light text ( to be used on a dark background )
        exec(null, null, "StatusBar", "styleLightContent", []);
    },

    styleBlackTranslucent: function () {
        // #88000000 ? Apple says to use lightContent instead
        exec(null, null, "StatusBar", "styleBlackTranslucent", []);
    },

    styleBlackOpaque: function () {
        // #FF000000 ? Apple says to use lightContent instead
        exec(null, null, "StatusBar", "styleBlackOpaque", []);
    },

    backgroundColorByName: function (colorname) {
        return StatusBar.backgroundColorByHexString(namedColors[colorname]);
    },

    backgroundColorByHexString: function (hexString) {
        if (hexString.charAt(0) !== "#") {
            hexString = "#" + hexString;
        }

        if (hexString.length === 4) {
            var split = hexString.split("");
            hexString = "#" + split[1] + split[1] + split[2] + split[2] + split[3] + split[3];
        }

        exec(null, null, "StatusBar", "backgroundColorByHexString", [hexString]);
    },

    hide: function () {
        exec(null, null, "StatusBar", "hide", []);
        StatusBar.isVisible = false;
    },

    show: function () {
        exec(null, null, "StatusBar", "show", []);
        StatusBar.isVisible = true;
    }

};

// prime it
exec(function (res) {
    if (typeof res == 'object') {
        if (res.type == 'tap') {
            cordova.fireWindowEvent('statusTap');
        }
    } else {
        StatusBar.isVisible = res;
    }
}, null, "StatusBar", "_ready", []);

module.exports = StatusBar;

});

 

你可能感兴趣的:(Cordova 小米8留海屏幕适配之沉状态栏与 适配大屏幕手机 从开始到结束 总结)