模块资源,窗口阴影,windows窗口程序,已杀毒处理,绿色纯净版
2025/8/16 10:29:53 219KB 资源开发
1
书名:无线通信基础原书名:FundamentalsofWirelessCommunication原出版社:CambridgeUniversityPress分类:电子电气>>通信作者:DavidTse,PramodViswanath译者:李锵周进等译;
马晓莉审校出版日期:2007-06-30语种:简体中文开本:16开页数:440定价:59.00元人民币目录第1章绪论11.1本书目标11.2无线系统21.3本书结构4第2章无线信道72.1无线信道的物理建模72.1.1自由空间、固定发射天线与接收天线82.1.2自由空间、运动天线92.1.3反射墙、固定天线102.1.4反射墙、运动天线112.1.5地平面反射122.1.6由距离和阴影引起的功率衰减132.1.7运动天线、多个反射体142.2无线信道的输入/输出模型142.2.1无线信道的线性时变系统142.2.2基带等效模型162.2.3离散时间基带模型182.2.4加性白噪声212.3时间相干与频率相干222.3.1多普勒扩展与相干时间222.3.2时延扩展与相干带宽232.4统计信道模型252.4.1建模基本原理252.4.2瑞利衰落与莱斯衰落262.4.3抽头增益自相关函数272.5文献说明312.6习题31第3章点对点通信:检测、分集与信道不确定性363.1瑞利衰落信道中的检测363.1.1非相干检测363.1.2相干检测393.1.3从BPSK到QPSK:自由度研究413.1.4分集433.2时间分集443.2.1重复编码443.2.2超越重复编码473.3天线分集523.3.1接收分集533.3.2发射分集:空时码543.3.3MIMO:一个2×2实例563.4频率分集613.4.1基本概念613.4.2具有ISI均衡的单载波623.4.3直接序列扩频673.4.4正交频分多路复用703.5信道不确定性的影响753.5.1直接序列扩频的非相干检测763.5.2信道估计773.5.3其他分集方案793.6文献说明813.7习题81第4章蜂窝系统:多址接入与干扰管理884.1概述884.2窄带蜂窝系统904.2.1窄带分配:GSM系统914.2.2对网络和系统设计的影响924.2.3对频率复用的影响934.3宽带系统:CDMA944.3.1CDMA上行链路954.3.2CDMA下行链路1054.3.3系统问题1064.4宽带系统:OFDM1074.4.1分配设计原理1084.4.2跳频模式1094.4.3信号特征与接收机设计1104.4.4扇区化1114.5文献说明1124.6习题113第5章无线信道的容量1215.1AWGN信道容量1215.1.1重复编码1225.1.2填充球体1225.2AWGN信道的资源1255.2.1连续时间AWGN信道1255.2.2功率与带宽1265.3线性时不变高斯信道1305.3.1单输入多输出(SIMO)信道1305.3.2多输入单输出(MISO)信道1315.3.3频率选择性信道1315.4衰落信道的容量1365.4.1慢衰落信道1365.4.2接收分集1385.4.3发射分集1405.4.4时间分集与频率分集1435.4.5快衰落信道1465.4.6发射端信息1495.4.7频率选择性衰落信道1565.4.8总结:观点的转变1565.5文献说明1585.6习题159第6章多用户容量与机会通信1676.1上行链路AWGN信道1686.1.1逐行干扰消除获得的容量1686.1.2与传统CDMA的比较1706.1.3与正交多址接入的比较1716.1.4一般K用户上行链路容量1726.2下行链路AWGN信道1736.2.1对称情况:获取容量的两种方案1746.2.2一般情况:叠加编码获取容量1766.3上行链路衰落信道1796.3.1慢衰落信道1796.3.2快衰落信道1806.3.3完整的信道辅助信息1826.4下行链路衰落信道18
1
在C#WinForm开发中,有时我们希望为窗体添加一些高级视觉效果,例如像现代操作系统中的窗口那样,带有四周的阴影。
这个效果可以提升应用的用户体验,使其看起来更加专业和精致。
本教程将详细讲解如何在WinForm取消默认边框后,实现窗体四周的阴影效果。
我们需要理解实现阴影效果的基本原理。
阴影通常是由底层图形API或自定义绘制来创建的,这里我们使用双层窗体结构:一层用于显示正常的窗体内容,另一层则用于绘制阴影。
这种方式可以确保阴影不影响到窗体上的控件交互。
以下是实现这一效果的关键步骤:1.**创建两个窗体**:-主窗体(MainForm):包含所有控件和应用程序的主要逻辑。
-阴影窗体(ShadowForm):用来绘制阴影效果,通常设置为透明,以保持主窗体内容的可见性。
2.**取消主窗体的默认边框**:在`MainForm`的设计界面或代码中,取消窗体的边框样式,如`FormBorderStyle=FormBorderStyle.None`,以使窗体无边框并能自由移动。
3.**自定义阴影窗体**:-创建`ShadowForm`类,继承自`Form`,并在其中重写`OnPaint`事件,以绘制阴影。
阴影可以通过渐变色、模糊效果等方式实现,具体取决于设计需求。
-设置`ShadowForm`的透明度,通常使用`Opacity`属性来调整,以便阴影既明显又不影响主窗体内容。
4.**同步主窗体和阴影窗体的位置与大小**:-当主窗体的位置或大小改变时,需要同步更新阴影窗体的位置和大小。
这可以通过监听`MainForm`的`LocationChanged`和`SizeChanged`事件来实现。
-在事件处理程序中,根据主窗体的位置和大小计算出阴影窗体的位置和大小,然后设置`ShadowForm`的相应属性。
5.**显示阴影窗体**:-在`MainForm`的`Load`事件或其他适当的时间点,实例化`ShadowForm`并将其设置为`TopLevel=false`,以防止它接管鼠标事件。
-将`ShadowForm`放置在`MainForm`下方,并设置适当的Z顺序,使其始终位于主窗体之下。
6.**处理窗体移动和关闭**:-要允许无边框的`MainForm`可移动,可以监听鼠标点击事件,然后使用`SetDesktopLocation`方法手动调整窗体位置。
-当主窗体关闭时,记得也要关闭`ShadowForm`,以保持程序的整洁。
通过以上步骤,我们可以成功地在WinForm应用中实现一个动态跟随主窗体的阴影效果。
需要注意的是,虽然WindowsForms提供了丰富的功能,但其图形渲染能力相比WPF等其他技术可能有所不足,因此在实现复杂视觉效果时可能会遇到一些限制。
不过,对于基本的阴影效果,以上方案已经足够实用。
为了更好地理解和实践这个效果,你可以从提供的压缩包文件“C#WinForm窗体四周阴影效果”中获取示例代码,根据代码结构和注释进行学习和调试。
这将帮助你更深入地掌握这个技术,并能将其应用到自己的项目中。
2025/7/30 23:16:16 82KB WinForm 阴影效果
1
在C#WinForm开发中,有时我们希望为窗体添加一些高级视觉效果,例如像现代操作系统中的窗口那样,带有四周的阴影。
这个效果可以提升应用的用户体验,使其看起来更加专业和精致。
本教程将详细讲解如何在WinForm取消默认边框后,实现窗体四周的阴影效果。
我们需要理解实现阴影效果的基本原理。
阴影通常是由底层图形API或自定义绘制来创建的,这里我们使用双层窗体结构:一层用于显示正常的窗体内容,另一层则用于绘制阴影。
这种方式可以确保阴影不影响到窗体上的控件交互。
以下是实现这一效果的关键步骤:1.**创建两个窗体**:-主窗体(MainForm):包含所有控件和应用程序的主要逻辑。
-阴影窗体(ShadowForm):用来绘制阴影效果,通常设置为透明,以保持主窗体内容的可见性。
2.**取消主窗体的默认边框**:在`MainForm`的设计界面或代码中,取消窗体的边框样式,如`FormBorderStyle=FormBorderStyle.None`,以使窗体无边框并能自由移动。
3.**自定义阴影窗体**:-创建`ShadowForm`类,继承自`Form`,并在其中重写`OnPaint`事件,以绘制阴影。
阴影可以通过渐变色、模糊效果等方式实现,具体取决于设计需求。
-设置`ShadowForm`的透明度,通常使用`Opacity`属性来调整,以便阴影既明显又不影响主窗体内容。
4.**同步主窗体和阴影窗体的位置与大小**:-当主窗体的位置或大小改变时,需要同步更新阴影窗体的位置和大小。
这可以通过监听`MainForm`的`LocationChanged`和`SizeChanged`事件来实现。
-在事件处理程序中,根据主窗体的位置和大小计算出阴影窗体的位置和大小,然后设置`ShadowForm`的相应属性。
5.**显示阴影窗体**:-在`MainForm`的`Load`事件或其他适当的时间点,实例化`ShadowForm`并将其设置为`TopLevel=false`,以防止它接管鼠标事件。
-将`ShadowForm`放置在`MainForm`下方,并设置适当的Z顺序,使其始终位于主窗体之下。
6.**处理窗体移动和关闭**:-要允许无边框的`MainForm`可移动,可以监听鼠标点击事件,然后使用`SetDesktopLocation`方法手动调整窗体位置。
-当主窗体关闭时,记得也要关闭`ShadowForm`,以保持程序的整洁。
通过以上步骤,我们可以成功地在WinForm应用中实现一个动态跟随主窗体的阴影效果。
需要注意的是,虽然WindowsForms提供了丰富的功能,但其图形渲染能力相比WPF等其他技术可能有所不足,因此在实现复杂视觉效果时可能会遇到一些限制。
不过,对于基本的阴影效果,以上方案已经足够实用。
为了更好地理解和实践这个效果,你可以从提供的压缩包文件“C#WinForm窗体四周阴影效果”中获取示例代码,根据代码结构和注释进行学习和调试。
这将帮助你更深入地掌握这个技术,并能将其应用到自己的项目中。
2025/7/30 23:16:15 82KB WinForm 阴影效果
1
C#自定义控件---实现Control阴影源码
2025/7/5 19:48:53 290KB net
1
目录第1章 HTML5简介11.1 HTML历史与HTML521.2 HTML5的优势61.3 HTML5的基本结构和语法变化81.4 本章小结12第2章 HTML5的常用元素与属性142.1 HTML5保留的常用元素152.2 HTML5增强的iframe元素342.3 HTML5保留的通用属性402.4 HTML5新增的通用属性442.5 HTML5新增的结构元素482.6 HTML5新增的语义元素552.7 HTML5头部和元信息592.8 HTML5新增的拖放API632.9 本章小结71第3章 HTML5表单相关的元素和属性723.1 HTML原有的表单及表单控件733.2 HTML5新增的表单属性833.3 HTML5新增的表单元素903.4 HTML5新增的客户端校验963.5 本章小结100第4章 HTML5的绘图支持1014.1 使用canvas元素1024.2 绘图1034.3 坐标变换1184.4 控制叠加风格1234.5 控制填充风格1244.6 位图处理1284.7 输出位图1324.8 动画制作1334.9 本章小结136第5章 HTML5的多媒体支持1375.1 使用audio和video元素1385.2 使用JavaScript脚本控制媒体播放1415.3 事件监听1445.4 track元素1465.5 本章小结149第6章 级联样式单与CSS选择器1506.1 样式单概述1516.2 CSS样式单的基本使用1526.3 CSS选择器1586.4 伪元素选择器1676.5 CSS3新增的伪类选择器1766.6 在脚本中修改显示样式1956.7 本章小结197第7章 字体与文本相关属性1987.1 字体相关属性1997.2 CSS3支持的颜色表示方法2057.3 文本相关属性2067.4 CSS3新增的服务器字体2127.5 本章小结215第8章 背景、边框和边距相关属性2168.1 盒模型简介2178.2 背景相关属性2178.3 使用渐变背景2268.4 边框相关属性2398.5 使用opacity控制透明度2468.6 padding和margin相关属性2478.7 本章小结249第9章 大小、定位、轮廓相关属性2509.1 width、height相关属性2519.2 定位相关属性2559.3 轮廓相关属性2579.4 用户界面和滤镜属性2589.5 本章小结263第10章 盒模型与布局相关属性26410.1 盒模型和display属性26510.2 对盒添加阴影27510.3 布局相关属性27810.4 CSS3新增的多栏布局28510.5 使用弹性盒布局28910.6 本章小结306第11章 表格、列表相关属性及mediaquery30711.1 表格相关属性30811.2 列表相关属性31311.3 控制光标的属性31611.4 mediaquery和响应式布局31711.5 本章小结323第12章 变形与动画相关属性32412.1 CSS3提供的变形支持32512.2 CSS3新增的3D变换33712.3 CSS3提供的Transition动画34112.4 CSS3提供的Animation动画34512.5 本章小结349第13章 JavaScript语法详解35013.1 JavaScript简介35113.2 数据类型和变量35613.3 基本数据类型36413.4 复合类型37613.5 运算符38113.6 语句39113.7 流程控制39513.8 函数40313.9 函数的参数处理42513.10 面向对象42913.11 创建对象43713.12 本章小结443第14章 DOM编程详解44414.1 DOM模型概述44514.2 DOM模型和HTML文档44614.3 访问HTML元素44814.4 修改HTML元素45614.5 增加HTML元素45814.6 删除HTML元素46314.7 传统的DHTML模型46714.8 使用window对象46914.9 navigator和地理定位47914.10 HTML5增强的HistoryAPI48514.11 使用do
2025/6/28 17:23:46 132.38MB web
1
简介:
Tailwind Ink是使用Tailwindcss颜色进行训练的AI调色板生成器。
Tailwind墨水Tailwind墨水是使用Tailwindcss颜色进行训练的AI调色板生成器。
警报:此工具是作为辅助项目而制作的,代码仍然杂乱无章。
它是如何工作的?它使用两个神经网络来预测整个调色板。
首先,models / shadesModel.js在给定某种颜色作为输入的情况下,从50-900垂直预测所有阴影。
第二个模型/model/nextModel.js在给定一定阴影作为输入的情况下水平预测所有颜色。
型号使用usi导入模型时
2025/6/15 19:57:05 1.65MB
1
视点变换,旋转,加速减速,星空背景太阳,光晕各行星纹理#include#include#include#include#include#include#include#pragmacomment(lib,"winmm.lib")#pragmacomment(lib,"wininet")//纹理图像结构typedefstruct{intimgWidth;//纹理宽度intimgHeight;//纹理高度unsignedcharbyteCount;//每个象素对应的字节数,3:24位图,4:带alpha通道的24位图unsignedchar*data;//纹理数据}TEXTUREIMAGE;//BMP文件头#pragmapack(2)typedefstruct{unsignedshortbfType;//文件类型unsignedlongbfSize;//文件大小unsignedshortbfReserved1;//保留位unsignedshortbfReserved2;//保留位unsignedlongbfOffBits;//数据偏移位置}BMPFILEHEADER;#pragmapack()//BMP信息头typedefstruct{unsignedlongbiSize;//此结构大小longbiWidth;//图像宽度longbiHeight;//图像高度unsignedshortbiPlanes;//调色板数量unsignedshortbiBitCount;//每个象素对应的位数,24:24位图,32:带alpha通道的24位图unsignedlongbiCompression;//压缩unsignedlongbiSizeImage;//图像大小longbiXPelsPerMeter;//横向分辨率longbiYPelsPerMeter;//纵向分辨率unsignedlongbiClrUsed;//颜色使用数unsignedlongbiClrImportant;//重要颜色数}BMPINFOHEADER;//定义窗口的标题、宽度、高度、全屏布尔变量#defineWIN_TITLE"模拟太阳系各星球的转动"constintWIN_WIDTH=800;constintWIN_HEIGHT=600;BOOLisFullScreen=FALSE;//初始不为全屏#defineDEG_TO_RAD0.017453floatangle=0.0;staticGLdoubleviewer[]={0,0,0,0,0};//初始化视角GLUquadricObj*quadric;//建立二次曲面对象GLfloatangle_Z;//星空旋转角度boolg_bOrbitOn=true;//控制转动暂停floatg_fSpeedmodifier=1.0f;//时间控制floatg_fElpasedTime;doubleg_dCurrentTime;doubleg_dLastTime;GLfloatLightAmbient[]={1.0f,1.0f,1.0f,0.0f};//环境光参数GLfloatLightDiffuse[]={1.0f,1.0f,1.0f,0.0f};//漫射光参数GLfloatLightPosition[]={0.0f,0.0f,0.0f,1.0f};//光源的位置//纹理图象TEXTUREIMAGEskyImg;TEXTUREIMAGEsunImg;TEXTUREIMAGErayImg;TEXTUREIMAGEmercuImg;TEXTUREIMAGEvenusImg;TEXTUREIMAGEearthImg;TEXTUREIMAGEmarsImg;TEXTUREIMAGEjupiterImg;TEXTUREIMAGEsaturnImg;TEXTUREIMAGEuranusImg;TEXTUREIMAGEneptuneImg;TEXTUREIMAGEmoonImg;GLuinttexture[12];//纹理数组//星球速度定义staticfloatfSunSpin=0.0f;//太阳自转速度staticfloatfMercuSpin=0.0f;//水星自转速度staticfloatfMercuOrbit=0.0f;//水星公转速度staticfloatfVenusSpin=0.0f;//金星自转速度staticfloatfVenusOrbit=0.0f;//金星公转速度staticfloatfEarthSpin=0.0f;//地球自转速度staticfloatfEarthOrbit=0.0f;//地球公转速度staticfloatfMarsSpin=0.0f;//火星自转速度staticfloatfMarsOrbit=0.0f;//火星公转速度staticfloatfJupiterSpin=0.0f;//木星自转速度staticfloatfJupiterOrbit=0.0f;//木星公转速度staticfloatfSaturnSpin=0.0f;//土星自转速度staticfloatfSaturnOrbit=0.0f;//土星公转速度staticfloatfUranusSpin=0.0f;//天王星自转速度staticfloatfUranusOrbit=0.0f;//天王星公转速度staticfloatfNeptuneSpin=0.0f;//海王星自转速度staticfloatfNeptuneOrbit=0.0f;//海王星公转速度staticfloatfMoonSpin=0.0f;//月亮自转速度staticfloatfMoonOrbit=0.0f;//月亮公转速度voidMakeTexture(TEXTUREIMAGEtextureImg,GLuint*texName)//转换为纹理{glPixelStorei(GL_UNPACK_ALIGNMENT,1);//对齐像素字节函数glGenTextures(1,texName);//第一个参数指定表明获取多少个连续的纹理标识符glBindTexture(GL_TEXTURE_2D,*texName);glTexParameterf(GL_TEXTURE_2D,GL_TEXTURE_WRAP_S,GL_REPEAT);glTexParameterf(GL_TEXTURE_2D,GL_TEXTURE_WRAP_T,GL_REPEAT);glTexParameterf(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);glTexParameterf(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR);glTexImage2D(GL_TEXTURE_2D,0,GL_RGB,textureImg.imgWidth,textureImg.imgHeight,0,GL_RGB,GL_UNSIGNED_BYTE,textureImg.data);}//初始化OpenGLvoidInitGL(void){glClearColor(0.0f,0.0f,0.0f,0.5f);//设置黑色背景glClearDepth(2.0f);//设置深度缓存glEnable(GL_DEPTH_TEST);//启动深度测试glDepthFunc(GL_LEQUAL);//深度小或相等的时候渲染glShadeModel(GL_SMOOTH);//启动阴影平滑glEnable(GL_CULL_FACE);//开启剔除操作效果glHint(GL_PERSPECTIVE_CORRECTION_HINT,GL_NICEST);//使用质量最好的模式指定颜色和纹理坐标的插值质量glLightfv(GL_LIGHT1,GL_AMBIENT,LightAmbient);//设置环境光glLightfv(GL_LIGHT1,GL_DIFFUSE,LightDiffuse);//设置漫反射光glEnable(GL_LIGHTING);//打开光照glEnable(GL_LIGHT1);//打开光源1//载入纹理glEnable(GL_TEXTURE_2D);//开启2D纹理映射MakeTexture(skyImg,&texture;[0]);MakeTexture(sunImg,&texture;[1]);MakeTexture(rayImg,&texture;[2]);MakeTexture(mercuImg,&texture;[3]);MakeTexture(venusImg,&texture;[4]);MakeTexture(earthImg,&texture;[5]);MakeTexture(marsImg,&texture;[6]);MakeTexture(jupiterImg,&texture;[7]);MakeTexture(saturnImg,&texture;[8]);MakeTexture(uranusImg,&texture;[9]);MakeTexture(neptuneImg,&texture;[10]);MakeTexture(moonImg,&texture;[11]);quadric=gluNewQuadric();//建立一个曲面对象指针gluQuadricTexture(quadric,GLU_TRUE);//建立纹理坐标gluQuadricDrawStyle(quadric,GLU_FILL);//面填充}voidDisplay(void){glLoadIdentity();//设置观察点的位置和观察的方向gluLookAt(viewer[0],viewer[1],viewer[2],viewer[3],viewer[4],-5,0,1,0);//摄像机x,摄像机y,摄像机z,目标点x,目标点y,目标点z,摄像机顶朝向x,摄像机顶朝向y,摄像机顶朝向z//获得系统时间使太阳系有动态效果g_dCurrentTime=timeGetTime();g_fElpasedTime=(float)((g_dCurrentTime-g_dLastTime)*0.0005);g_dLastTime=g_dCurrentTime;glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);glMatrixMode(GL_MODELVIEW);//指定GL_MODELVIEW是下一个矩阵操作的目标glTranslatef(0.0f,0.0f,-5.0f);//将坐标系移入屏幕5.0fglRotatef(10,1.0f,0.0f,0.0f);//将坐标系绕x轴旋转10度glEnable(GL_LIGHT0);//打开光源0/**********************************绘制背景星空********************************************/glPushMatrix();//当前模型矩阵入栈glTranslatef(-10.0f,3.0f,0.0f);glRotatef(angle_Z,0.0f,0.0f,1.0f);glEnable(GL_TEXTURE_2D);glBindTexture(GL_TEXTURE_2D,texture[0]);//星空纹理glBegin(GL_QUADS);glNormal3f(0.0f,0.0f,1.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(-50.0f,-50.0f,-50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(50.0f,-50.0f,-50.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(50.0f,50.0f,-50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(-50.0f,50.0f,-50.0f);glEnd();glBegin(GL_QUADS);glNormal3f(0.0f,0.0f,-1.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(-50.0f,-50.0f,50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(50.0f,-50.0f,50.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(50.0f,50.0f,50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(-50.0f,50.0f,50.0f);glEnd();glBegin(GL_QUADS);glNormal3f(0.0f,1.0f,0.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(-50.0f,-50.0f,-50.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(50.0f,-50.0f,50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(50.0f,-50.0f,-50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(-50.0f,-50.0f,50.0f);glEnd();glBegin(GL_QUADS);glNormal3f(0.0f,-1.0f,0.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(-50.0f,50.0f,-50.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(50.0f,50.0f,50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(50.0f,50.0f,-50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(-50.0f,50.0f,50.0f);glEnd();glBegin(GL_QUADS);glNormal3f(1.0f,0.0f,0.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(-50.0f,-50.0f,-50.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(-50.0f,50.0f,50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(-50.0f,-50.0f,50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(-50.0f,50.0f,-50.0f);glEnd();glBegin(GL_QUADS);glNormal3f(-1.0f,0.0f,0.0f);glTexCoord2f(6.0f,6.0f);glVertex3f(50.0f,-50.0f,-50.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(50.0f,50.0f,50.0f);glTexCoord2f(6.0f,0.0f);glVertex3f(50.0f,-50.0f,50.0f);glTexCoord2f(0.0f,6.0f);glVertex3f(50.0f,50.0f,-50.0f);glEnd();glPopMatrix();//当前模型矩阵出栈/**********************************绘制太阳************************************************/glBindTexture(GL_TEXTURE_2D,texture[2]);//光晕纹理glEnable(GL_BLEND);//开启混合glDisable(GL_DEPTH_TEST);//关闭深度测试//绘制太阳光晕glDisable(GL_LIGHTING);//关闭光照glBlendFunc(GL_SRC_ALPHA,GL_ONE);//半透明混合函数glColor4f(1.0f,0.5f,0.0f,0.5f);//设置RGBA值glBegin(GL_QUADS);glNormal3f(0.0f,0.0f,1.0f);glTexCoord2f(0.0f,0.0f);glVertex3f(-1.0f,-1.0f,0.0f);glTexCoord2f(1.0f,0.0f);glVertex3f(1.0f,-1.0f,0.0f);glTexCoord2f(1.0f,1.0f);glVertex3f(1.0f,1.0f,0.0f);glTexCoord2f(0.0f,1.0f);glVertex3f(-1.0f,1.0f,0.0f);glEnd();glDisable(GL_BLEND);//关闭混合glEnable(GL_DEPTH_TEST);glEnable(GL_LIGHTING);//开启光照glLightfv(GL_LIGHT1,GL_POSITION,LightPosition);//设置光源1位置glBindTexture(GL_TEXTURE_2D,texture[1]);//太阳纹理//将坐标系绕Y轴旋转fSunSpin角度,控制太阳自转glRotatef(fSunSpin,0.0,1.0,0.0);gluSphere(quadric,0.3f,32,32);//绘制太阳球体/**********************************绘制水星************************************************/glDisable(GL_LIGHT0);glEnable(GL_TEXTURE_2D);//开启纹理glPushMatrix();//当前模型视图矩阵入栈//将坐标系绕Y轴旋转fMercuOrbit角度,控制水星公转glRotatef(fMercuOrbit,0.0f,1.0f,0.0f);glRotatef(-90.0f,1.0f,0.0f,0.0f);//将坐标系绕X轴旋转-90度glTranslatef(0.5f,0.0f,0.0f);//将坐标系右移0.5fglBindTexture(GL_TEXTURE_2D,texture[3]);//水星纹理//将坐标系绕Z轴旋转fMercuSpin角度控制水星自转glRotatef(fMercuSpin,0.0f,0.0f,1.0f);gluSphere(quadric,0.04f,32,32);//水星球体glPopMatrix();//当前模型视图矩阵出栈//绘制轨道glBegin(GL_LINE_LOOP);for(angle=0;angle=-6.0)viewer[0]-=0.5;break;case'u':case'U':if(viewer[1]=-6.0)viewer[1]-=0.1;break;case'+':case'='://加速,减速,暂停g_fSpeedmodifier+=1.0f;glutPostRedisplay();break;case'':g_bOrbitOn=!g_bOrbitOn;glutPostRedisplay();break;case'-'://按'-'减小运行速度g_fSpeedmodifier-=1.0f;glutPostRedisplay();break;caseVK_ESCAPE://按ESC键时退出exit(0);break;default:break;}}voidspecial_keys(ints_keys,intx,inty){switch(s_keys){caseGLUT_KEY_F1://按F1键时切换窗口/全屏模式if(isFullScreen){glutReshapeWindow(WIN_WIDTH,WIN_HEIGHT);glutPositionWindow(30,30);isFullScreen=FALSE;}else{glutFullScreen();isFullScreen=TRUE;}break;caseGLUT_KEY_RIGHT://视角上下左右旋转if(viewer[3]=-3.0)viewer[3]-=0.1;break;caseGLUT_KEY_UP:if(viewer[4]=-4.5)viewer[4]-=0.1;break;default:break;}}voidmouse(intbtn,intstate,intx,inty)//远近视角{if(btn==GLUT_RIGHT_BUTTON&&state==GLUT_DOWN)viewer[2]+=0.3;if(btn==GLUT_LEFT_BUTTON&&state==GLUT_DOWN&&viewer;[2]>=-3.9)viewer[2]-=0.3;}voidLoadBmp(char*filename,TEXTUREIMAGE*textureImg)//载入图片{inti,j;FILE*file;BMPFILEHEADERbmpFile;BMPINFOHEADERbmpInfo;intpixel_size;//初始化纹理数据textureImg->imgWidth=0;textureImg->imgHeight=0;if(textureImg->data!=NULL){delete[]textureImg->data;}//打开文件file=fopen(filename,"rb");if(file==NULL){return;}//获取文件头rewind(file);fread(&bmpFile;,sizeof(BMPFILEHEADER),1,file);fread(&bmpInfo;,sizeof(BMPINFOHEADER),1,file);//验证文件类型if(bmpFile.bfType!=0x4D42){return;}//获取图像色彩数pixel_size=bmpInfo.biBitCount>>3;//读取文件数据textureImg->data=newunsignedchar[bmpInfo.biWidth*bmpInfo.biHeight*pixel_size];for(i=0;idata+(i*bmpInfo.biWidth+j)*pixel_size+2,sizeof(unsignedchar),1,file);//绿色分量fread(textureImg->data+(i*bmpInfo.biWidth+j)*pixel_size+1,sizeof(unsignedchar),1,file);//蓝色分量fread(textureImg->data+(i*bmpInfo.biWidth+j)*pixel_size+0,sizeof(unsignedchar),1,file);//Alpha分量if(pixel_size==4){fread(textureImg->data+(i*bmpInfo.biWidth+j)*pixel_size+3,sizeof(unsignedchar),1,file);}}}//记录图像相关参数textureImg->imgWidth=bmpInfo.biWidth;textureImg->imgHeight=bmpInfo.biHeight;textureImg->byteCount=pixel_size;fclose(file);}//程序主函数voidmain(intargc,char**argv){//读图片LoadBmp("Picture//Sky.bmp",&skyImg;);LoadBmp("Picture//Sun.bmp",&sunImg;);LoadBmp("Picture//Ray.bmp",&rayImg;);LoadBmp("Picture//Mercu.bmp",&mercuImg;);LoadBmp("Picture//Venus.bmp",&venusImg;);//金星LoadBmp("Picture//Earth.bmp",&earthImg;);LoadBmp("Picture//Mars.bmp",&marsImg;);//火星LoadBmp("Picture//Jupiter.bmp",&jupiterImg;);//木星LoadBmp("Picture//Saturn.bmp",&saturnImg;);//土星LoadBmp("Picture//Uranus.bmp",&uranusImg;);//天王星LoadBmp("Picture//Neptune.bmp",&neptuneImg;);//海王星LoadBmp("Picture//Moon.bmp",&moonImg;);glutInit(&argc;,argv);//初始化GLUT库glutInitDisplayMode(GLUT_RGBA|GLUT_DOUBLE|GLUT_DEPTH);//初始化显示模式glutInitWindowSize(WIN_WIDTH,WIN_HEIGHT);//初始化窗口大小glutInitWindowPosition(20,20);//初始化窗口位置GLuintwindow=glutCreateWindow(WIN_TITLE);//建立窗口InitGL();//初始化OpenGLglutDisplayFunc(Display);glutReshapeFunc(Reshape);glutKeyboardFunc(keyboard);glutSpecialFunc(special_keys);glutMouseFunc(mouse);glutIdleFunc(Display);//设置窗口空闲时的处理函数glutMainLoop();//进入事件处理循环}
2025/6/8 20:47:10 3.53MB 三维动画 模拟太阳系
1
纯CSS3实现的各种阴影效果,无需图片和js代码即可实现图片、按钮等元素的阴影效果,完全通过样式控制阴影大小、方向和深度,经测试效果相当不错非常酷。
2025/5/31 15:08:39 42KB CSS3阴影效果
1
全部打包了!Consolas+微软雅黑混合字体,以及字体效果增强工具ClearType!1、安装ClearType;
2、YaHei.Consolas.1.12.ttf,下载安装在C:\WINDOWS\Fonts就可以了;3、在你想应用雅黑字体库的地方,选择YaHei.Consolas的字体就可以了;
注意:有时候可能你应用了字体会有阴影效果,这时候你就可以在控制>ClearTypeTuning,勾选TurnOnClearType就可以了;
你电脑上的窗口从白花花的颜色变成淡淡的苹果绿。
设置方法:1、打开控制面板中的"显示"选择外观(appearance)-高级(advanced),然后在项目(items)那栏选窗口(windows),再点颜色(color)-其它(others),然后把Hue(色调设为85,Sat(饱和度)设为90,Lum(亮度)设为205。
然后单击添加到自定义颜色(Addtocustomcolors),按“OK”...一直OK。
2、桌面-右键-属性-外观-高级-项目-窗口(记住选窗口啊)-颜色-其它,色调设为85,饱和度设为90,亮度设为205。
然后单击[添加到自定义颜色]-确定...一路确定。
3、把窗口设成绿色之后,再来把IE的网页背景也变成养眼的绿色吧:打开IE,点击工具(TOOLS),点INTERNET选项(INTERNETOPTIONS),点右下角的辅助功能(Assessibility),然后勾选不使用网页中指定的颜色(ignorecolorsspecifiedonwebpages),然后点“OK”退出。
1
共 105 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡