官方站点:http://workshop.chromeexperiments.com/examples/gui/

Dat.gui 使用教程:Dat.gui 是一个 GUI 组件,他可以为你的 demo 提供参数的设置。并且很容易上手。

基础用法

引入js 文件

<script type="text/javascript" src="https://raw.github.com/dataarts/dat.gui/master/build/dat.gui.min.js"></script>

初始化配置

var Options = function() {
this.message = 'dat.gui';
this.speed = 0.8;
this.displayOutline = false;
this.button = function() {};
}; window.onload = function() {
var options = new Options();
var gui = new dat.GUI(); gui.add(options, 'message');
gui.add(options, 'speed', -5, 5);
gui.add(options, 'displayOutline');
gui.add(options, 'button');
};

这里,在你的配置项:FizzyText 里,GUI 会根据你设置的属性类型来渲染不同的控件

  • 如果是Number 类型则用 slider来控制
  • 如果是 Boolean 类型,则用 Checkbox来控制
  • 如果是 Function 类型则用 button 来控制
  • 如果是 String 类型则用 input 来控制

控制输入限制

控制限制输入项输入类型以及值

gui.add(text, 'noiseStrength').step(5); // 增长的步长
gui.add(text, 'growthSpeed', -5, 5); // 最大、最小值
gui.add(text, 'maxSize').min(0).step(0.25); // 最大值和步长 // 文本输入项
gui.add(text, 'message', [ 'pizza', 'chrome', 'hooray' ] ); // 下拉框形式选择文案
gui.add(text, 'speed', { Stopped: 0, Slow: 0.1, Fast: 5 } );

选项组

可以使用文件夹给选项分组

var gui = new dat.GUI();

var f1 = gui.addFolder('Flow Field');
f1.add(text, 'speed');
f1.add(text, 'noiseStrength'); var f2 = gui.addFolder('Letters');
f2.add(text, 'growthSpeed');
f2.add(text, 'maxSize');
f2.add(text, 'message'); f2.open();

颜色值的输入

提供4种类型颜色输入控制

  • CSS
  • RGB
  • RGBA
  • Hue
var Options = function() {
this.color0 = "#ffae23"; // CSS string
this.color1 = [ 0, 128, 255 ]; // RGB array
this.color2 = [ 0, 128, 255, 0.3 ]; // RGB with alpha
this.color3 = { h: 350, s: 0.9, v: 0.3 }; // Hue, saturation, value
}; window.onload = function() { var options = new Options();
var gui = new dat.GUI(); gui.addColor(options, 'color0');
gui.addColor(options, 'color1');
gui.addColor(options, 'color2');
gui.addColor(options, 'color3');
};

存储

可以使用 remember 方法开启 GUI 的存储模式,而且可以分组存储

var Options = function() {
this.color0 = "#ffae23"; // CSS string
}; window.onload = function() {
var options = new Options();
var gui = new dat.GUI(); gui.remember(options); gui.addColor(options, 'color0');
};

当然你也可以把之前保存的数据在初始化时导入

var Options = function() {
this.number = 1;
}; window.onload = function() {
var options = new Options();
var gui = new dat.GUI({
load:{
"preset": "kkkkk",
"closed": false,
"remembered": {
"Default": {
"0": {
"number": 4
}
},
"kkkkk": {
"0": {
"number": 6
}
}
},
"folders": {}
}
}); gui.remember(options);
gui.add(options, 'number').min(0).max(10).step(1);
};

可以通过 preset 配置项指定使用哪个分组的配置

事件

你可以为每一项设置一个监听事件 onChangeonFinishChange

var Options = function() {
this.number = 1;
}; window.onload = function() {
var options = new Options();
var gui = new dat.GUI();
var controller = gui.add(options, 'number').min(0).max(10).step(1); controller.onChange(function(value) {
console.log("onChange:" + value)
}); controller.onFinishChange(function(value) {
console.log("onFinishChange" + value)
});
};

获取面板DOM对象

可以通过 gui.domElement 获取原生 dom 对象

从GUI外部控制配置项

如果你想从外部控制选项,你可以为选项调用 listen 方法,则你改变option时,也会同步到面板里

var Options = function() {
this.number = 1;
}; window.onload = function() {
var options = new Options();
var gui = new dat.GUI();
var controller = gui.add(options, 'number').min(0).max(10).step(1).listen(); setInterval(function() {
options.number = Math.random() * 10;
}, 500)
};

最新文章

  1. 修改hosts文件在本地使域名解析到指定IP
  2. 例子:Alarm Clock with voice Commands Sample
  3. MFC 最大化 的时候控件 按比例变大
  4. CATransition(过渡)
  5. 帝国cms栏目别名如何调用?
  6. 解决错误提示: 未找到 Oracle 客户端和网络组件。
  7. 【转】如何优化Cocos2d-X游戏的内存
  8. a-b(高精度)
  9. DPC定时器
  10. Esxi主机虚拟机迁移注意事项
  11. POJ2599+POJ2082【最大矩形面积】
  12. 正方形网格 TRIANGLE_STRIP连接
  13. .NET中利用反射来实现自动映射两个对象中的数据成员
  14. 教你理解微信小程序的生命周期和运行原理
  15. activiti uuid主键
  16. 微信小游戏开发Canvas资源汇总
  17. Day14 Python基础之os/sys/hashlib模块(十二)
  18. 洛谷P1038神经网络题解
  19. post-image.sh hacking
  20. scrapy框架学习之路

热门文章

  1. 各种常用的CDN加速服务
  2. Sqlserver 实际开发中表变量的用法
  3. shell函数传递带空格的参数
  4. jQuery源代码 框架分析
  5. jQuery的Pagenation分页插件。
  6. 【BZOJ3721】PA2014 Final Bazarek 贪心
  7. rtmp直播拉流客户端EasyRTMPClient TCP窗口大小设计方法
  8. 怎么用cookie解决选项卡问题刷新后怎么保持原来的选项?
  9. windowsphone8.1学习笔记之应用数据(二)
  10. 九度OJ 1179:阶乘 (循环)