Android 4.4之后谷歌提供了沉浸式全屏体验, 在沉浸式全屏模式下, 状态栏、 虚拟按键动态隐藏, 应用可以使用完整的屏幕空间, 按照 Google 的说法, 给用户一种 身临其境 的体验。而Android 5.0之后谷歌又提出了 ColorPalette 的概念,让开发者可以自己设定系统区域的颜色,使整个 App 的颜色风格和系统的颜色风格保持统一。

在没有CCSystemBar之前,用Delphi实现上面的功能,是件很麻烦的事情,前期的博文也有写这方面的实现。现在这一切变的简单了!

先看一下CCSystemBar的方法:

    procedure TranslucentStatusBar;

    function checkDeviceHasNavigationBar: Boolean;//检查是否有底部的导航条
function checkNavigationBarShow: Boolean;//检查是否显示了底部的导航行
function getStatusBarPixelHeight(): Integer;//
function getStatusBarPointHeight(): Single;//获取StatusBar顶部状态栏Point高度
function getNavigationBarPixelHeight(): Integer;
function getNavigationBarPointHeight(): Single;//获取NavigationBar底部导航栏Point高度

了解了这个控件提供的方法,现在看看怎么具体使用:

1.拖一下控件到Form上,一般就是主Form了,然后再手工填加引用的单元:CC.VirtualKeyboard

2.放一个Toolbar,设置为Top,也可以用TRectangle,反正用一个可视控件,占用屏的顶部。接下来用CCSystemBar取得的状态条的高度来设置Toolbar的内边距:

AToolBar.Padding.Top := self.CCSystemBar1.getStatusBarPointHeight;

这是作者提供的例子使用的方法,也可以换用其他实现方式,比如:就用一个TRectangle来占用状态条区域。

3.按上面的实现,同理处理底部导航条,放置一个Toolbar,Align设置为MostBottom。

procedure TMainForm.SetNavigationBarHeight(AToolBar: TToolBar);
begin
if self.CCSystemBar1.checkNavigationBarShow then
begin
AToolBar.Height := self.CCSystemBar1.getNavigationBarPointHeight;
end
else
begin
AToolBar.Height := ;
end;
end;

看代码,如果导航条显示,则设置其高度为系统导航条的高度,反之,设置为0.

4.为了适应系统虚拟键盘的显示与隐藏,我们还需要处理Form的FormVirtualKeyboardHidden及FormVirtualKeyboardShown事件:

procedure TMainForm.FormVirtualKeyboardHidden(Sender: TObject;
KeyboardVisible: Boolean; const Bounds: TRect);
begin
SetNavigationBarHeight
(self.NavigationBar);
end; procedure TMainForm.FormVirtualKeyboardShown(Sender: TObject;
KeyboardVisible: Boolean; const Bounds: TRect);
begin
SetNavigationBarHeight
(self.NavigationBar);
end;

5.在Form.OnCreate事件中,初始化状态条及导航条的高度:

procedure TMainForm.FormCreate(Sender: TObject);
begin
self.CCSystemBar1.TranslucentStatusBar;//适应低版本的android,必须调用。
SetStatusBarPadding(self.StatusBar);
SetNavigationBarHeight(self.NavigationBar); end;

6.发布配置文件:

打开Deployment窗口,如上图,取掉自带的styles.xml及styles-v21.xml,填加ChinaCock带的对应文件。

启动图片换成loading.png发布,去掉系统自带的splash_image_def.xml文件。

Ok,万事大吉,运行app!

后记:

2020-04-01,需要注意,项目设置中,Include splash image必须勾选,如下图:

我因为这个问题,造成应用不正常显示了!

ChinaCock界面控件介绍-CCSystemBar的更多相关文章

  1. ChinaCock界面控件介绍-CCNavigateTitle

    先看一下实际项目中的运行效果,如图,通过品牌的导航栏,显示不同品牌的商品列表. 完全基于ChinaCock控件包中CCNavigateTitle组件实现的,这是一个可视控件,从组件面板上拖放一个到Fo ...

  2. ChinaCock界面控件介绍-CCLoadingIndicator

    这是一个显示等待状态的控件,当在线程中执行一个稍长时间的任务,需要显示一个等待过程,免得让用户不知app在做什么?避免用户寂寞. 先看看这个控件的属性说明: BackgroundTransparenc ...

  3. ChinaCock界面控件介绍-TCCYearMonthSelector

    Delphi原生控件支持日期的选择,但对于只选择年月的情况,则没有好的实现.TCCYearMonthSelector正是为解决这个问题而产生的.看看运行效果图: 用法一如即往的简单,这是一个不可视控件 ...

  4. ChinaCock界面控件介绍-TCCImageViewerForm

    有多个图片,左右滑动可以切换,通过手势还可以放大.缩小查看,象常见的相册,就是这样子实现效果. 现在,我们有了TCCImageViewerForm组件,也可以轻松实现这样的场景应用. 现在看看TCCI ...

  5. ChinaCock界面控件介绍-CCButton

    即将发布的ChinaCock新版本,将带来一个CCButton控件,实现可视按钮.Delphi原生的Button,在上面滑动后,当释放手指时会误触发OnClick事件,这不是我们想要的结果,CCBut ...

  6. ChinaCock界面控件介绍-TCCBarcodeCreator

    条码生成器,可以生成各种条码,包括二维码.这是一个不可视控件.用起来依旧简单. 属性说明: BarCodeColor:生成条码的颜色 BarcodeFormat:生成条码的类型,支持的条码类型: Bo ...

  7. ChinaCock界面控件介绍-CCGridPictureEditor

    CCGridPictureEditor如其名,网格图片编辑控件,实现利用一个网格来显示多张图片的缩略图,这是一个非常实用的控件,实现类似微信朋友圈中发布多张图片的功能. 在没有这个控件之前,我都是用D ...

  8. ChinaCock界面控件介绍-CCNewsSilder

    上图是控件包里的Demo运行效果,轮播新闻图片. 这个控件用起来简单,拖放一个CCNewsSiler到Form上,设置Align为Top,再设置好高度,然后用代码加载图片: procedure TFo ...

  9. ChinaCock打印控件介绍-TCCFujitsuPrinter实现蓝牙针式打印

    项目中遇到,要蓝牙针式打印机,用手机打印表单.感谢专家,对厂家提供的SDK进行了封装,实现利用Delphi开发出这一功能. 现在来看看,如何利用这一控件实现打印过程: procedure startS ...

随机推荐

  1. MySql之安装以及设置密码等

    1.MySQL的下载安装.简单应用及目录介绍 1.下载安装 windows10的:https://www.cnblogs.com/clschao/articles/9916971.html linux ...

  2. 『MXNet』第三弹_Gluon模型参数

    MXNet中含有init包,它包含了多种模型初始化方法. from mxnet import init, nd from mxnet.gluon import nn net = nn.Sequenti ...

  3. 移动端rem适配 flex.js

    (function() { document.addEventListener('DOMContentLoaded', function () { var html = document.docume ...

  4. 46. Permutations C++回溯法

    基本的回溯法 注意每次回溯回来要把上次push_back()进去的数字pop掉! class Solution { public: void backTrack(vector<int> n ...

  5. 提高Bash使用效率的方法

    环境:centos6.5 1.移动 Ctrl + a :移到命令行首Ctrl + e :移到命令行尾 Ctrl + xx:在命令行首和光标之间移动 左右键移动字符 Ctrl+左右键移动单词(不记快捷键 ...

  6. PHP手册-函数参考-加密扩展

    一.Crack.CSPRNG.Hash.Mcrypt.Mhash.OpenSSL.密码散列算法的对比   Crack CSPRNG Hash Mcrypt Mhash OpenSSL 密码散列算法 简 ...

  7. ajax实现给JavaScript中全局变量赋值(转)

    原文地址:ajax实现给JavaScript中全局变量赋值 问题简化: <script type="text/javascript"> var a=1 ; functi ...

  8. ajax请求二进制流图片并渲染到html中img标签

    日常显示图片都诸如这种形式:直接使用img的src属性 <img src="图片路径.地址" alt="" /> 以上方法无法在获取图片请求中设置请 ...

  9. 【LeetCode】区间合并

    给定一组区间,将所有区间重叠的部分合并起来. e.g. 给出 { [1, 3], [2, 6], [8, 10], [15, 18] },返回 { [1, 6], [8, 10], [15, 18] ...

  10. oracle in 函数

    IN操作符      select * from scott.emp where empno=7369 or empno=7566 or empno=7788 or empno=9999:      ...