QSettings之 beginGroup()、childKeys() 、value()

QSettings之 beginGroup()、childKeys() 、value()


1. void QSettings:: beginGroup()

void QSettings::​beginGroup(const QString & prefix)

Appends prefix to the current group.

给当前的group里由QSettings指定的所有键(key),自动附上当前的group前缀。另外,一些查询函数例如childGroups(), childKeys(), allKeys() ,是基于group操作的。

对于路径相同的设置,使用group可以省去重复敲入路径名称的麻烦。例如:

settings.beginGroup("mainwindow");
settings.setValue("size", win->size());
settings.setValue("fullScreen", win->isFullScreen());
settings.endGroup();
 
settings.beginGroup("outputpanel");
settings.setValue("visible", panel->isVisible());
settings.endGroup();

上面代码会设置三组设置的值:

mainwindow/size

mainwindow/fullScreen

outputpanel/visible

组(groups)能够形成网络。调用beginGroup()后,需要调用endGroup(), 复位当前的组(group)。即:beginGroup()和endGroup()成套使用,否则会形成group网络。


 

2. QStringList QSettings:: childKeys() const

QStringList QSettings::​childKeys() const

返回QSttings对象的所有顶层keys的一个列表。

例如:

QSettings settings;
settings.setValue("fridge/color", QColor(Qt::white));
settings.setValue("fridge/size", QSize(32, 96));
settings.setValue("sofa", true);
settings.setValue("tv", false);
QStringList keys = settings.childKeys();// keys: ["sofa", "tv"]

如果一个groupbeginGroup()进行了group的设置,则返回的这个group里的顶层keys,不含group前缀。

settings.beginGroup("fridge");
keys = settings.childKeys();// keys: ["color", "size"]

通过递归调用childKeys() 和childGroups() ,可以遍历整个设置的各个层级。


3. Qvaiant Qsettings::value()

QVariant QSettings::​value(const QString & key, const QVariant & defaultValue = QVariant()) const

返回键(key)的值。如果键不存在,返回默认值;如果没有指定默认值,返回默认的QVariant值。

注意:windows注册表和INI文件的键名(keys),大小写不区分;而Mac OS XCarbon Preference API的键名(keys),区分大小写,也就是,大小写敏感。

例如:

QSettings settings;
settings.setValue("animal/snake", 58);
settings.value("animal/snake", 1024).toInt();   // returns 58
settings.value("animal/zebra", 1024).toInt();   // returns 1024
settings.value("animal/zebra").toInt();         // returns 0


  • 2
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值