简单日历

​ 主要目的是学习函数模块划分,成品大概是这样,加了一些花里胡哨的东西(/▽\)

分三个模块,主函数.c 显示.c 计算.c 与.h 文件

有两种实现方式,区别在于是否以数组在模块之间传递。

第一种-用数组进行保存日历页

1.主函数.c

输入信息并控制

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include "calendar1.h"
#include <stdbool.h>
#include <string.h>
#define ON 1
#define OFF 0 int main( )
{
int year = 2019;
int month = 7;
char op[10] = { 0 };
int button = 1;
do
{
calen_cal(year,month);
calen_display(year, month,button);
scanf(" %s", op);
if( !strcmp(op, "ON") ) {
button = 1; continue;
}
if( !strcmp(op, "OFF") ) {
button = 0; continue;
}
if( *op == 'U' || *op == 'u' )
{
if( month == 1 )
{
--year;
month = 12;
}
else --month;
continue;
}
if( *op == 'D' || *op == 'd' )
{
if( month == 12 )
{
++year;
month = 1;
}
else ++month;
continue;
}
if( *op == 'R' || *op == 'r' )break; printf("请按以下格式输入:2019-7\n");
int temY, temM;
scanf("%d-%d", &temY, &temM);
if( is_right(temY, temM) )
{
year = temY; month = temM;
}
} while( true );
}
2.计算函数相关.c

计算( •̀ ω •́ )✧

​```c
#include <stdio.h> #include "calendar.h"
int months[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 }; int is_leepyear(int year)//是否为闰年
{
return ( year % 4 == 0 && year % 100 != 0 || year % 400 == 0 );
}
int is_right(int year, int mon) //输入的年份或月份是否正确
{
return ( year > 1900 && mon <= 12 && mon >= 1 );
}
int first_day_index(int year, int mon)//返回该月第一天的下标 0-6
{
if( is_leepyear(year) )months[1] = 29;
else months[1] = 28; int days = 0;
for( int i = mon - 1; i > 0; --i )
{
days += months[i - 1];
}
for( int i = year - 1; i >= 1900; --i )
{
if( i % 4 == 0 && i % 100 != 0 || i % 400 == 0 ) days += 366;
else days += 365;
}
return days % 7;
} int Last_days(int year, int mon)// 返回上个月最后一天的天数,用来排日历中的上一月信息
{
if( mon == 1 )return 31;
else return months[mon - 2];
} void calen_cal(int *calen,int year,int mon,int index)//将排好的信息放到数组中
{
int Last_day = Last_days(year, mon);
int count = 0;
//排上个月
for( int i = 1; i <= index; ++i, ++count )
{
calen[count]=Last_day - index + i;
}
//排本月
for( int i = 1; i <= months[mon - 1]; ++i, ++count )
{
calen[count] = i;
}
//排下月
for( int i = 1; count < 42; ++i, ++count )
{
calen[count] = i;
}
} ​```
3. 打印显示.c

花里胡哨的显示

​```c
#include <stdio.h>
#include <Windows.h>
#include "calendar.h"
void calen_print(int *calen, int button, int index)
{
//打印上一月
int i = 0;
for( i = 1; i <= index; ++i )
{
if( button == 1 )printf("%5d", calen[i - 1]);
else printf(" ");
if( i % 7 == 0 )putchar(10);
}
//打印本月
for( ; calen[i - 1] != 1; ++i )
{
printf("%5d", calen[i - 1]);
if( i % 7 == 0 )putchar(10);
}
//打印下一月
for( ; i <= 42; ++i )
{
if( button == 1 )printf("%5d", calen[i - 1]);
else printf(" ");
if( i % 7 == 0 )putchar(10);
}
}
void calen_ui(int *calen, int button, int index,int year,int mon)
{
system("cls");
//这块是更改控制台颜色
srand(time(NULL));
int rand_color;
HANDLE hConsole = GetStdHandle(STD_OUTPUT_HANDLE);
// rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
printf("%d-%d U/D\n", year, mon); rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
printf("Mon Tue Wed Thu Fri Sat Sun\n"); rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
printf("--------------------------------------\n"); rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
calen_print(calen, button,index); rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
printf("--------------------------------------\n"); rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
printf("U/u 向上翻页,D/d向下翻页,R/r退出,ON/OFF是否显示其他天数,输入其他进入日期跳转模式\n"); rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color); } ​```
4. 头文件.h

头文件声明

​```c
void calen_ui(int *calen, int button, int index, int year, int mon);
void calen_cal(int *calen, int year, int mon,int index);
int first_day_index(year, mon);
​```

用c写的简单的日历(学习模块划分)的更多相关文章

  1. 使用JAVA写一个简单的日历

    JAVA写一个简单的日历import java.text.DateFormat;import java.text.ParseException;import java.text.SimpleDateF ...

  2. js写一个简单的日历

    思路:先写一个结构和样式,然后写本月的时间,之后计算上下月份的关系 <!DOCTYPE html> <html lang="en"> <head> ...

  3. 使用SSI框架写的简单Demo(查询模块)

    在网上看到好多个版本,自己有时间索性就写个Demo记录下整个框架的逻辑流程: 1.首先拷贝整个框架所需要的jar包到WEB-INF/lib包下(这个网上都可以搜到的) 2.配置文件的配置, 2.1.在 ...

  4. 【UI插件】简单的日历插件(下)—— 学习MVC思想

    前言 我们上次写了一个简单的日历插件,但是只是一个半成品,而且做完后发现一些问题,于是我们今天尝试来解决这些问题 PS:距离上次貌似很久了 上次,我们大概遇到哪些问题呢: ① 既然想做一套UI库,那么 ...

  5. laravel学习:php写一个简单的ioc服务管理容器

    php写一个简单的ioc服务管理容器 原创: 陈晨 CoderStory 2018-01-14 最近学习laravel框架,了解到laravel核心是一个大容器,这个容器负责几乎所有服务组件的实例化以 ...

  6. 用C#Winform写个简单的批量清空文件内容和删除文件的小工具

    用C#Winform写个简单的批量清空文件内容和删除文件的小工具 本文介绍这个简单得不能再简单的小项目.做这个项目,有以下目的. 1 当然是做个能用的工具 2 学习使用Github 关于用VS2013 ...

  7. 自己用js写的两个日历控件

    前一阵写了两个日历控件,做了简单的封装,发出来共朋友们参考. 第一个日历控件,条状的日历. (使用方法:调用initBarTime(id,evn),第一个参数是要渲染div的id,第二个参数是点击日期 ...

  8. (原创)如何使用boost.asio写一个简单的通信程序(一)

    boost.asio相信很多人听说过,作为一个跨平台的通信库,它的性能是很出色的,然而它却谈不上好用,里面有很多地方稍不注意就会出错,要正确的用好asio还是需要花一番精力去学习和实践的,本文将通过介 ...

  9. jstorm开发指南-写个简单的jstorm应用

    jstorm开发指南-写个简单的jstorm应用 发表于 2015-07-18   |   分类于 大数据   |   暂无评论 jstorm 是阿里巴巴开源的基于storm采用Java重写的一套分布 ...

随机推荐

  1. Face Recognition 人脸识别该如何测试

    猪圈子,一个有个性的订阅号 01 测量人脸识别的主要性能指标有 1.误识率(False;Accept;Rate;FAR):这是将其他人误作指定人员的概率; 2.拒识率(False;RejectRate ...

  2. js作用域其二:预解析

    文章目錄 解析机制 JavaScript是一门解释型的语言 , 想要运行js代码需要两个阶段 编译阶段: 编译阶段就是我们常说的JavaScript预解析(预处理)阶段,在这个阶段JavaScript ...

  3. JS实现总价随数量变化而变化(顾客购买商品表单)

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:test.html * 作者:常轩 * 微信公众号:Worldh ...

  4. 8——PHP循环结构&&条件结构

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...

  5. PyQt5之俄罗斯方块

    上个礼拜有个需求,对csv里的数据按条件进行拆分计算.一想到要做计算,少不了pandas.还有个要求最好是生成命令行工具或者带有界面. 于是尝试下,使用PyQt5做了个简单的UI界面给程序包个壳子,然 ...

  6. 7-7 jmu_python_是否是数 (10 分)

    本题要求从键盘输入一个字符串,判断该串是否属于整数.浮点数或者复数的表示 输入格式: 输入一个字符串 输出格式: 输出yes或no 输入样例: -299 输出样例: yes a = input() t ...

  7. 前端小姐姐学PHP之(二)

    上次了我们配置好开发环境了,本小节主要讲述内容点: phpStrom的运行环境配置 创建数据库.数据表 连接数据库 一.phpStrom的运行环境配置(windows版) 注:MAC版原文地址 htt ...

  8. moment太重? 那就试试miment--一个超轻量级的js时间库

    介绍 Miment 是一个轻量级的时间库(打包压缩后只有1K),没有太多的方法,Miment的设计理念就是让你以几乎为零的成本快速上手,无需一遍一遍的撸文档 由来 首先 致敬一下Moment,非常好用 ...

  9. node中fs模块 - fs.open() fs.read() fs.write() fs.close()

    var fs = require('fs') fs.open('./a.txt', 'a+', function(err, fd) { // 打开文件后 创建缓冲区放置数据 ), // 读取多少字节 ...

  10. JZOJ 1154. 【GDOI2003】购物

    1154. [GDOI2003]购物 (Standard IO) Time Limits: 1000 ms Memory Limits: 65536 KB Description GDOI商场推出优惠 ...