- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用我的 fitbit 来帮助了解我更容易进入健身房的距离。使这更简单,因此解决方案更容易为人们提供帮助。
我正在使用 fitbit 和一些基本的 JS。
使用时钟 API,我可以创建一个计时器,但不能通过按钮触发。
即,这可以完成工作。
import clock from "clock";
import document from "document";
import { preferences } from "user-settings";
import * as util from "../common/utils";
import { display } from "display";
// Update the clock every minute
clock.granularity = "seconds";
// Get a handle on the <text> element
const ClockLabel = document.getElementById("timeLabel");
const Timer= document.getElementById("timerLabel");
const myButton = document.getElementById("button-1");
myButton.text = "button";
// Update the <text> element every tick with the current time
clock.ontick = (evt) => {
var Timing = 4*60*60
let today = evt.date;
var diff = Timing - ((today - start)/1000 |0);
let hours = (diff / 3600) | 0;
let minutes = ((diff - (hours*3600)) / 60) | 0;
let seconds = diff - (hours * 3600) - (minutes * 60)| 0;
console.log("hours:"+hours+", minutes:"+minutes+", seconds:"+seconds);
let hours = today.getHours();
let minutes = today.getMinutes();
let seconds = today.getSeconds();
if (preferences.clockDisplay === "12h") {
// 12h format
hours = hours % 12 || 12;
} else {
// 24h format
hours = util.zeroPad(hours);
}
ClockLabel.text = `${hours}:${minutes}:${seconds}`;
}
但是,当从按钮触发时,它不起作用。
myButton.addEventListener("click", (evt) => {
var start = Date.now()
//also this doesn't work let today = evt.date;
myButton.text = "Started";
var Timing = 4*60*60;
var diff = Timing - ((Date.now() - start)/1000 |0);
let hours = (diff / 3600) | 0;
let minutes = ((diff - (hours*3600)) / 60) | 0;
let seconds = diff - (hours * 3600) - (minutes * 60)| 0;
console.log("hours:"+hours+", minutes:"+minutes+", seconds:"+seconds);
ClockLabel.text = `${hours}:${minutes}:${seconds}`;
});
这使我得出结论,使用此功能可能是更好的前进方式。
function CountDownTimer(duration, granularity) {
this.duration = duration;
this.granularity = granularity || 1000;
this.tickFtns = [];
this.running = false;
}
CountDownTimer.prototype.start = function() {
if (this.running) {
return;
}
this.running = true;
var start = Date.now(),
that = this,
diff, obj;
(function timer() {
diff = that.duration - (((Date.now() - start) / 1000) | 0);
if (diff > 0) {
setTimeout(timer, that.granularity);
} else {
diff = 0;
that.running = false;
}
obj = CountDownTimer.parse(diff);
that.tickFtns.forEach(function(ftn) {
ftn.call(this, obj.minutes, obj.seconds);
}, that);
}());
};
CountDownTimer.prototype.onTick = function(ftn) {
if (typeof ftn === 'function') {
this.tickFtns.push(ftn);
}
return this;
};
CountDownTimer.prototype.expired = function() {
return !this.running;
};
CountDownTimer.parse = function(seconds) {
return {
'hours': (seconds / 3600)|0,
'minutes': (seconds / 60) | 0,
'seconds': (seconds % 60) | 0
};
};
export default CountDownTimer;
最佳答案
根据您的问题:如何在申请中显示当前时间?... 在大多数情况下,您的代码看起来不错。
获取当前时间,正常js date
ref from FitBit
恕我直言,您有几个选择1
) 使用 tick
事件 API 或 2
) 使用来自 Fitbit Studio 的示例时钟应用程序并使用您的代码对其进行自定义。
最后,我在最后添加了一些自定义代码来帮助您更新格式/显示/标签,请根据您的需要进行调整..
option 1 Tick Event Approach: For e.g. option with clock face to get the current time you need to use the date API or the the
tick event
which contains thedate object
as the picture, it also saves you battery life!
option 2 Modify Sample Approach: Take the sample getting started app and modify it ref sample to help you and the below sample
1. Recommended: you can follow the sample https://dev.fitbit.com/getting-started/
2. There are three files you can peek/update/play around
3. Move your crunching code here -> Apps>index.js
4. Plan/put on the UI/Face -> Resource>index.gui
5. Modify styles via css, font etc. here -> Resource>styles.css
let day = today.getDate(); // and the get the time from there. or tick event
this below code also has some boilerplate to wire up and help you with the display please modify as per your needs
import clock from "clock";
import document from "document";
import { preferences } from "user-settings";
import * as util from "../common/utils";
//import { me as appbit } from "appbit";
import { display } from "display";
//import * as messaging from "messaging";
// Update/Display the text, get a handle on the <text> element
const timeLabel = document.getElementById("timeLabel");
const dateLabel = document.getElementById("dateLabel");
// just threw this in for your ** Medication.. you need to configure/add it
// const MedicationReminder = document.getElementById("MedicationLabel");
clock.granularity = "seconds";
// Update the <text> element every tick with the current time
clock.ontick = (evt) => {
let today = evt.date;
let hours = today.getHours();
if (preferences.clockDisplay === "12h") {
// 12h format
hours = hours % 12 || 12;
} else {
// 24h format
hours = util.zeroPad(hours);
}
let minutes = util.zeroPad(today.getMinutes());
let seconds = util.zeroPad(today.getSeconds());
let day = util.zeroPad(today.getDate());
let month = util.zeroPad(today.getMonth() + 1);
let year = today.getFullYear();
// update like so
timeLabel.text = `${hours}:${minutes}:${seconds}` ;
function setDateDisplay(obj, d, m, y, format) {
let date;
if(format) {
date = `${m}/${d}/${y}`;
}
else {
date = `${d}/${m}/${y}`;
}
obj.text = date;
settings.USDateFormat = format;
}
关于javascript - Fitbit - 计时器 - 如何在应用程序中显示当前时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67558014/
我有一个包含数字和整数的文件,我只想读取整数, 如果它们令人讨厌,请忽略宏,但是我只需要有整数,但是我必须确保还要读取字符串,然后忽略它们 我必须在这里修改什么: #include #include
我有一个这样格式化的txt文件: MyDepartureTown MyDestinationTown 123.45 Vehicle 12 我正在尝试将数据导入到我的 C 程序中。这是我用来实现这一目标
我创建了一个简单的文件,使用 flex,它生成了一个文件 lex.yy.c,现在,我想把它放到 C++ 程序中。 %{ #include %} %% stop printf("Stop co
我的一个程序用 c++ 代码生成一个大文件。有没有办法从另一个C++类调用将生成的代码插入其中? 这是一个小例子,可以清楚地说明我想要实现的目标。 生成的文件示例: FirstClass first
我需要了解我的程序“检查输入十六进制消息的第三个位置” 程序将采用十六进制值输入消息。例如0x0123456789abcdef 程序将检查输入消息的第三个位置,即 0 现在程序将采用另一条十六进制值的
当我将输入从输入文件重定向到 yacc 程序时,在它完成解析文件后,我希望 yacc 解析器打印其所做操作的摘要。如果我通过键盘输入内容然后按 Ctrl+D,我希望它执行相同的操作。有办法做到这一点吗
我正在扫描该文件,但它有两种不同的结构。 文件: ParisRoubaix "Marco MARCATO" 33 UAD ITA 26 5:43:31 ParisRoubaix "Sam BEWLEY
我想将winsock2.lib 添加到我的程序中,但不希望将其包含到最终的可执行文件中。有什么方法可以让我动态加载与winsock2关联的dll吗?如果没有,是否有任何 dll(Windows 附带)
我尝试了一个基本程序来将数据从数据库表检索到java程序中。编译结束后,运行代码时出现异常。控制台中没有显示错误。显示异常消息 import java.sql.*; public class clas
我想用 C++ 创建一个跨平台安装程序。它可以是任何压缩类型,例如 zip 或 gzip,像普通安装程序一样嵌入程序本身。我不想在不同的平台、linux 和 windows 上创建很多更改。如何跨平台
每次尝试用鼠标输入两个顶点时,我都会崩溃。我最近改变了组织每个形状的方式,以确保新形状与旧形状重叠。 这个项目的想法是制作各种交互式 Canvas 。用户可以在直线、三角形和矩形之间进行选择,然后选择
我想在我的程序中显示以下文本。当我在 python 中粘贴以下文本时,它会将反斜杠解释为转义序列并弄乱我的 ascii 艺术..任何解决这个问题的想法极客。这是我的文本想出现在我的节目中 _ _
我正在尝试加载名为 Tut16_ReadText.txt 的文件,并使其运行程序以输出其重或轻。 我收到了粘贴在下面的错误。我无法抽出时间让这个程序运行。谁能解释一下我必须做什么才能使这个程序正常工作
我想使用命令行将列表作为参数传递,例如: $python example.py [1,2,3] [4,5,6] 我希望第一个列表 [1,2,3] 成为 first_list,[4,5,6] 成为 se
在分析 C# 应用程序时,我发现名为“ThePreStub”的系统 (?) 方法中有相当多的 CPU 使用率。这是什么? 最佳答案 参见:CLR Inside out - The Performanc
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 9 年前。 Improve this qu
我正在用 Python 开发一个游戏,想知道如何给它自己的图标。我使用的是 Windows 计算机,没有安装 Python 的额外东西。哦,我也在使用 3.3 版,这甚至可能吗? P.S 我在 Sta
我正在使用 tkinter 使用 Python 开发一个项目,该项目将允许对 IP 地址进行地理定位。我有原始转换,我可以获取 IP 地址并知道城市、州、国家、经度、纬度等。我想知道是否有任何方法可以
我编写了一个程序,您可以在其中选择任意数字并将其与任意数字的幂相关联。代码运行正常,直到它到达某个部分,然后我必须输入一个字符以使其移动到代码的下一部分。这就是我的意思: #include int
我正在编写“HACKING Art Of Exploitation”一书练习 Convert2.c 第 61 页。 这是我的代码。下面是我的问题。 #include void usage(char
我是一名优秀的程序员,十分优秀!