C# 浮点转时间
想了大半天实在想不出什么更适合文章的标题。。。
就现在这个标题,挺好- -
什么是浮点转时间呢?
今天写的一个计时功能,想来想去还是现在这种解决方案比较合适
先上一张图在来讲解比较明了
如图:赛车游戏的计时
计时格式为:分'秒'毫秒
先来个脑筋急转弯让大家乐乐
已知:
1小时=60分
1分=60秒
1秒=?毫秒
敲了四年代码今天我居然会掉进这个坑里!!估计脑袋短路了吧- -
按照这个逻辑1秒=60毫秒,这是完全错误的!1秒=1000毫秒才是正确的答案
好吧,请深深的鄙视我吧。。。
其实这篇文章没有什么高深的东西,主要说这种解决方案还是不错滴
怎么个不错法呢,听我一一道来
可以看见上图中有一个“个人记录”一栏
如果我们要把这个数据存在数据库中,咋存?
用存日期时间的方式?
用文本?
在这里我用的是浮点型
从游戏开始计算,一局游戏我到完成花费了150.12秒
我就直接把150.12存进数据库,然后读取的时候在把这个数转换成 分/秒/毫秒 这样的格式
可以看见当 分/秒/毫秒 为一位数时,会自动补0,比如:01 02 03 这样
所以我们现在要做的是,获取时间:totalTime += Time.deltaTime;
然后在相对应的计算出 分/秒/毫秒
我写了一个方法,这个方法仅供我计时用
其他地方反正用不上,就不考虑扩展性什么的了
参考一下我的思路就行!上代码
/// 计算时间 <summary>
/// 计算时间
/// </summary>
/// <param name="_Convert">欲计算的文本</param>
/// <param name="_point">小数点左=0;右=1</param>
/// <returns>返回格式 00</returns>
private string CalcTime(string _Convert, int _point)
{
string[] temSplit = _Convert.Split(new char[] { '.' }); if (Convert.ToInt32(temSplit[_point]) < )
return ("" + temSplit[_point]).Replace("-", ""); //被整除的时候为'-.--',所以直接替换成0
return (temSplit[_point].Substring(, ) + temSplit[_point].Substring(, )).Replace("-","");
}
没错,你没有看错,我用的就是这么简单的方法
调用的代码
void FixedUpdate()
{
totalTime += Time.deltaTime;
temMinute = CalcTime(Convert.ToDouble(totalTime / 60f).ToString("0.00"), );
temSeconds = CalcTime(Convert.ToDouble(totalTime - Convert.ToDouble(temMinute) * 60f).ToString("0.00"), );
temMilli = CalcTime(Convert.ToDouble(totalTime - Convert.ToDouble(temMinute) * 60f).ToString("0.00"), );
}
好吧,真的一点不高深,纯属看思路
也没啥好说的,随便看看吧
我游戏功能要实现的功能还有一大堆,先闪了
写得不好勿喷
本文链接:http://www.cnblogs.com/shenggege/p/4251123.html
C# 浮点转时间的更多相关文章
- mysql基本介绍和优化技巧
一. mysql框架和基本介绍 1. 框架图 更详细: 2. 存储引擎 MYISAM与INNODB对比: MYISAM:mysql5.1及以前版本的默认存储引擎.支持全文检索,压缩,表级锁等,但不支持 ...
- 【转】Java 中字符串的格式化
原文网址:http://blog.csdn.net/aimartt/article/details/8307237 参考资料:JDK API 1.6.0 中文文档 1.格式字符串语法 产生格式化输出的 ...
- 再探Java基础——String.format(String format, Object… args)的使用
最近看到类似这样的一些代码:String.format("参数%s不能为空", "birthday"); 以前还没用过这功能不知咐意思,后研究了一下,详细讲解如 ...
- Mysql学习(慕课学习笔记3)数据类型
数据类型 数据类型是指.存储过程参数.表达式和局部变量的数据特征, 它决定了数据的存储格式,代表了不同的信息类型. 整型 Tinyint 有符号位 -128到127 无符号位 0到255 ...
- java String.Format详解
JDK1.5中,String类新增了一个很有用的静态方法String.format(): format(Locale l, String format, Object... args) 使用指定的语言 ...
- Vertica: 基于DBMS架构的列存储数据仓库
介绍 Vertica(属于HP公司),是一个基于DBMS架构的数据库系统,适合读密集的分析型数据库应用,比方数据仓库,白皮书中全名称为VerticaAnalytic Database.从命名中也可以看 ...
- String.Format in Java and C#
原文:String.Format in Java and C# JDK1.5中,String类新增了一个很有用的静态方法String.format(): format(Locale l, String ...
- java基础-day28
第05天 MySQL 今日内容介绍 u 数据库的概述 u MySQL和SQLyog的安装和使用 u SQL语句 第1章 数据库的概述 1.1 数据库的概述 1.1.1 概述 l 什么是数据库 ...
- mysql数据库的笔记
增删改查置顶: 插入数据: 基本语法 : insert into [表名](字段名1,字段名2……) values(记录1),(记录2): insert into [表名] values(记录1),( ...
随机推荐
- CopyOnWriteArrayList介绍
CopyOnWrite容器即写时复制的容器.通俗的理解是当我们往一个容器添加元素的时候,不直接往当前容器添加,而是先将当前容器进行Copy,复制出一个新的容器,然后新的容器里添加元素,添加完元素之后, ...
- ZOJ 1709 Oil Deposits(dfs,连通块个数)
Oil Deposits Time Limit: 2 Seconds Memory Limit: 65536 KB The GeoSurvComp geologic survey compa ...
- JAVA并发-线程状态
一.线程基本状态 新建:线程已创建但start()方法还没执行 就绪(可运行):start()方法已运行,但还没被选择 运行:从就绪线程中选择出某一个线程进行run()操作 阻塞(不可运行):线程正在 ...
- mysql千万级数据库插入速度和读取速度的调整
mysql上百万数据读取和插入更新一般没什么问题,但上千万后速度会很慢,如何调整配置,提高效率.如下: 1.尽量将数据一次性写入DataFile和减少数据库的checkpoint操作,调整如下参数: ...
- 协作开发中常用的Git命令小结
先提一下最基础的git命令用法: git clone 从远端克隆到本地仓库 git add . (注意add和. 之间有一个空格)将全部改动添加到暂存区 git checkout xxx 撤销更改 ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 044-45
记录今日刷题 ------------------------------------------------L1-044--------------------------------------- ...
- wait();notify();简单例子
public class Test1{ /** * @param args */ public static void main(String[] args) { new Thread(new Thr ...
- MySQL 5.7增强半同步测试
we've know the machenism of semi-synchronous replication in my previous article,let's do som ...
- MySQL(mariadb)多实例应用与多实例主从复制
MySQL多实例 mysql多实例,简单理解就是在一台服务器上,mysql服务开启多个不同的端口(如3306.3307,3308),运行多个服务进程.这些 mysql 服务进程通过不同的 socket ...
- js判断当前浏览器是否是源生app的webview
有些时候,我们在开发过程中需要判断,当前页面被打开是否是处于源生的webview里面,或者NODEJS做服务器后端支持的时候,判断请求来源是否来至于源生webview里面被打开的页面请求GET/POS ...