昨日亲测可用,资源分不多,请大家作为模板使用,稍加修饰即可
2025/10/6 11:52:36 8.5MB html5 jquery 背景音乐 动态效果
1
仿QQ概念版登陆界面,酷狗魔方,C#winForm.Net2.0界面特效源码。
可以把Winform设计成像WPF一样。
仿QQ概念版登陆界面:云和叶子是动态的。
启动和关闭有仿照QQ的渐变透明的动态效果。
酷狗魔方:4个角有淡入淡出效果。
还有其他几个特效例子。
此项目中包含了多个界面设计例子。
VS2013。
界面库不开源,如果你需要源码你可以联系我。
本项目只用于学习参考,请勿用于非法或商务用途,谢谢合作!
2025/10/5 4:51:51 3.75MB QQ概念版 酷狗魔方 C# winForm
1

"plchart图表"是一款专为数据可视化设计的工具,它提供了丰富的图表类型和灵活的定制选项,使得用户能够轻松地创建出美观且具有洞察力的数据展示。
235K的大小表明这是一个轻量级的解决方案,适合各种环境,尤其是那些对资源消耗有严格限制的项目。
在实际应用中,"plchart"通常被用作数据分析和报告的一部分,它能够帮助用户将复杂的数据转化为易于理解的图形。
例如,你可以使用它来创建柱状图、折线图、饼图、散点图以及热力图等多种图表类型,这些图表在商业智能、科研分析或者教育教学等场景下都非常常见。
"使用实例都包括在内"意味着下载的压缩包中可能包含了一些示例代码或预设的图表模板,这对于初学者来说是极其宝贵的资源。
通过查看和修改这些实例,用户可以快速掌握plchart的使用方法,并了解到如何根据自己的数据调整图表参数,以达到最佳的视觉效果。
在"效果集合"部分,很可能包含了plchart的各种预览效果,展示了它在不同应用场景下的表现。
这不仅让用户能直观地看到图表的样式和功能,也便于他们在设计时寻找灵感。
可能涵盖动态效果、交互式操作以及自定义主题等方面,使得最终的图表既实用又具有吸引力。
"plchart"可能支持多种编程语言,如JavaScript、Python或者PHP等,因此无论你熟悉哪种语言,都能找到相应的接口来调用和控制图表。
此外,其可能还提供了详细的API文档和用户手册,帮助开发者更好地理解和利用这个库。
在实际操作中,使用plchart创建图表的步骤通常包括:导入数据、选择合适的图表类型、设置图表属性(如颜色、大小、标签等)、添加交互功能(如点击事件、数据悬停提示等)以及调整布局和样式。
对于高级用户,可能还需要了解如何自定义图表组件,以满足特定的需求。
"plchart图表"是一个全面的数据可视化工具,它集易用性、灵活性和功能性于一体,适用于各种需要数据展示的场合。
通过深入学习和实践,你可以用它来创建出专业且引人入胜的图表,提升数据的解析度和沟通效率。
2025/6/19 23:26:24 235KB
1

这篇内容将围绕“灰色渐变边框个人简历模板”这一主题,深入探讨如何利用网页模板设计一份具有专业感和个人特色的简历。
在这个数字化时代,一份出色的在线简历能够为求职者增添亮点,提高竞争力。
我们要了解的是“简历”在IT行业的应用。
在求职过程中,简历是展示个人技能、经历和成就的重要工具。
而随着互联网技术的发展,电子简历或在线简历变得越来越普遍,它们可以更直观地展示求职者的个性和专业能力,通过网页形式的简历,可以添加动态效果、多媒体元素,使内容更加生动。
“网页模板”是创建网页的一种快捷方式。
它提供了预设的布局、颜色方案和设计元素,使得非专业设计师也能快速构建出美观的网页。
在这个案例中,“灰色渐变边框个人简历模板”可能包含了一套简洁、专业的设计风格,利用灰色调的渐变边框来营造稳重而不失现代感的视觉效果。
在压缩包文件中,我们看到以下几个关键文件:1. **style.css**:这是CSS(Cascading Style Sheets)样式表文件,用于定义网页的样式,包括字体、颜色、布局等。
在这个模板中,它可能包含了边框的渐变效果和其他页面元素的样式规则。
2. **index.html**:这是HTML(HyperText Markup Language)文件,是网页的主体结构,包含文本、图像和其他元素的标记。
在这个简历模板中,它会指导浏览器如何呈现个人信息、工作经历、技能等部分。
3. **_desktop.ini**:这是一个系统文件,通常用于设置Windows系统中文件夹的属性,例如图标、显示方式等。
在这个上下文中,它可能与模板的桌面视图配置有关。
4. **ReadMe.txt**:这是一个常见的文本文件,通常包含关于软件或项目的基本信息、使用指南或注意事项。
在这个压缩包中,它可能会提供关于如何使用这个模板的说明。
5. **松设计漂亮的网页-mobanwang.com.url**:这是一个书签文件,指向一个网页设计资源网站,可能提供了更多模板或者其他设计相关的资源。
6. **images**:这是一个文件夹,通常包含网页中使用的图像文件。
在这个模板中,可能会有头像、示例作品或其他增强视觉效果的图片。
通过编辑和定制这些文件,用户可以根据自己的需求调整简历模板,例如替换个人照片、修改文字内容、调整边框样式等,以创造出独一无二的在线简历。
对于求职者而言,掌握基本的HTML和CSS知识可以帮助更好地利用这类模板,进一步优化自己的简历,提升求职成功率。
2025/6/19 16:47:07 28KB
1

在IT行业中,"loading 页面等侯加载demon"这一主题主要涉及到用户体验、前端开发和页面优化等关键领域。
"Loading"页面,也被称为加载页面或进度指示器,是用户在访问网页或应用时,系统处理内容并准备显示的过渡阶段所看到的界面。
这种页面设计的目的在于提供反馈,让用户知道系统正在工作,并且可以预期何时完成。
我们要理解"等待加载"(Waiting for Loading)的概念。
在网页或应用启动时,如果内容加载时间较长,用户可能会感到不耐烦或者疑惑是否发生了错误。
因此,一个有效的加载页面能够缓解用户的焦虑,通过展示动态效果或进度条来告知用户他们的操作正在被处理。
这在大数据量、高延迟或复杂交互的场景中尤其重要。
"Demon"在这里可能指的是后台进程或者服务,即在后台默默运行并处理加载任务的部分。
在前端开发中,"demon"可以是一个JavaScript服务,负责监听和管理数据加载状态,确保加载页面与实际内容的同步。
此外,"demon"也可能指代后端的异步处理,如Web Workers或后台任务,它们在不影响主线程性能的情况下进行资源加载。
加载页面的设计有多种策略。
一种是预加载,它在用户尚未请求内容时就开始加载,以缩短实际展示内容的时间。
另一种是按需加载,也称为懒加载,只在用户滚动到相关内容区域时才开始加载,这样可以减少初始加载时间,提升页面速度。
前端技术在实现加载页面时通常会用到HTML、CSS和JavaScript。
HTML用于构建页面结构,CSS用于美化加载动画,而JavaScript则负责动态控制加载过程,例如显示或隐藏加载提示,以及与服务器的交互。
在"loading-master"这个压缩包文件中,可能包含了一个完整的加载页面示例项目。
通常,这样的项目会包括以下文件和目录:1. `index.html` - 主页文件,包含了加载页面的基本结构。
2. `style.css` 或 `styles.scss` - 样式表,定义了加载动画的样式和布局。
3. `script.js` 或 `main.ts` - JavaScript脚本,控制加载逻辑和交互。
4. `images` 或 `assets` - 图片和其他静态资源,可能包含加载动画的图片序列。
5. `README.md` - 项目的说明文档,介绍如何运行和使用项目。
在实际开发中,开发者还会考虑SEO(搜索引擎优化)、A/B测试以优化加载页面的效果,以及对不同设备和浏览器的兼容性问题。
此外,随着Web技术的发展,WebAssembly和Service Worker等新技术也可以用于提升加载性能,为用户提供更流畅的体验。
总结起来,"loading 页面等侯加载demon"是关于如何通过优化加载页面提升用户体验的重要课题,涉及到前端开发的多个层面,包括设计、交互、性能优化和资源管理。
"loading-master"这个项目可能就是一个实践这些概念的实际案例,通过学习和研究,我们可以更好地理解和掌握这一领域的知识。
2025/6/19 12:08:07 132KB
1

在C#编程环境中,开发一个实时的医疗波形图或曲线图可以极大地帮助医疗专业人员监控病人的生理数据。
这个项目使用了微软的Windows Forms库中的`Chart`控件和`Timer`控件来实现这一功能。
下面我们将深入探讨这两个关键组件以及如何将它们结合应用于医疗数据可视化。
`Chart`控件是.NET Framework提供的一种强大的图表绘制工具,能够绘制各种类型的图表,如折线图、柱状图、饼图等。
在医疗领域,折线图常用于展示病人的心电图、血压、血氧饱和度等随时间变化的趋势。
`Chart`控件提供了丰富的定制选项,包括数据系列、轴设置、图表区、图例、数据点样式等,使得开发者可以根据实际需求创建出符合标准的医疗图表。
接下来,`Timer`控件在本项目中起到了关键作用,它周期性地触发事件,使程序能够实时更新图表数据。
在医疗监测应用中,数据通常需要连续不断地获取并实时显示,以反映出病人的最新状态。
`Timer`的`Tick`事件可以在指定间隔内调用,用于刷新图表数据,确保数据的实时性。
开发者需要在此事件处理函数中更新`Chart`控件的数据源,并调用`Invalidate()`方法强制重绘图表,实现动态效果。
为了创建这样一个实时波形图,你需要遵循以下步骤:1. **创建Windows Forms应用程序**:在Visual Studio中启动一个新的Windows Forms项目。
2. **添加Chart控件**:从工具箱中拖拽一个`Chart`控件到Form上,调整其大小和位置。
3. **配置Chart控件**:设置图表类型为折线图(`Series.ChartType = SeriesChartType.Line`),并根据需要配置轴标签、单位等。
4. **添加Timer控件**:同样从工具箱中拖拽一个`Timer`控件,设置其Interval属性以决定数据更新的频率(例如,每秒一次)。
5. **编写Tick事件处理函数**:在`Timer.Tick`事件中,获取实时数据(模拟数据或从传感器读取),然后将这些数据添加到`Chart`控件的系列中。
6. **更新图表**:每次添加数据后,调用`Chart.Invalidate()`以刷新图表。
7. **运行程序**:启动应用程序,观察波形图是否能实时更新。
在`DemoRealChart`这个项目中,可能包含了示例代码、资源文件或者设计界面的`.Designer.cs`文件。
通过查看这些文件,你可以看到具体实现的细节,比如数据的生成逻辑、图表的样式设置等。
对于初学者,这将是一个很好的学习案例,了解如何将理论知识转化为实际应用。
总结起来,使用C#的`Chart`控件和`Timer`控件创建医疗波形图,是实现医疗数据实时可视化的有效方法。
通过理解这两个控件的工作原理和使用方式,开发者可以构建出满足各种需求的医疗监测系统,为临床决策提供有力支持。
2025/6/15 22:22:38 54KB
1
在Android开发中,自定义View是一项常见的任务,它允许开发者根据特定需求创建独特且功能丰富的UI元素。
本示例中的“自定义View实现仪表盘(账户安全)Demo”旨在展示如何构建一个能够显示用户账户安全等级的仪表盘。
这个仪表盘可以直观地向用户展示他们的账户安全性,例如通过颜色、刻度或指针的变化来表示不同的安全级别。
要实现自定义View,我们需要创建一个新的Java类,继承自`View`或者它的子类,如`LinearLayout`、`RelativeLayout`等。
在这个例子中,我们可能会选择`View`作为基类,因为我们需要从头开始构建仪表盘的全部视觉元素。
在类中,我们可以重写`onDraw()`方法,这是绘制自定义图形的核心函数。
在`onDraw()`中,我们使用`Canvas`对象进行绘图操作。
`Canvas`提供了多种绘制图形的方法,如`drawRect()`,`drawCircle()`,`drawArc()`,`drawPath()`等。
对于仪表盘,我们可能需要使用`drawArc()`来绘制表盘的背景和指针,用`drawText()`来添加刻度值和安全等级文字。
仪表盘的结构通常包括一个中心圆环(代表表盘),外围的刻度线,以及一个可移动的指针来指示当前的安全等级。
我们可以根据安全等级计算出指针旋转的角度,并利用`rotate()`方法将其设置为相应的角度。
此外,颜色编码也是仪表盘的一个重要组成部分,比如绿色表示安全,黄色表示警告,红色表示危险。
为了使仪表盘具有动态效果,可以监听数据变化,如用户的安全分数更新。
当分数改变时,更新指针角度和颜色,然后调用`invalidate()`或`postInvalidate()`来触发`onDraw()`的再次执行,实现视图的刷新。
在“Test_Customview2”这个文件中,可能包含了自定义仪表盘View的源代码、布局文件以及测试用例。
布局文件(可能是`activity_main.xml`)将自定义View添加到UI层次结构中,以便在应用中显示。
测试用例可能用于验证仪表盘的正确渲染和行为,确保在不同安全等级下能正确显示。
为了提高代码的可维护性和复用性,还可以考虑将仪表盘组件封装成一个独立的库,提供配置接口供其他开发者调整颜色、刻度数量、指针样式等参数。
这样,这个自定义View就能更方便地应用到其他项目中。
“自定义View实现仪表盘(账户安全)Demo”展示了如何在Android中创建一个自定义的UI组件,通过编程方式绘制出仪表盘并动态响应数据变化。
这样的技术对于开发者来说是提升应用用户体验和界面差异化的重要手段。
通过深入理解和实践这个Demo,开发者可以进一步掌握Android自定义View的设计与实现。
2025/6/15 0:01:33 1.42MB
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
该程序是用VC++编写的,运行时是一个球绕一个锥形物体旋转的动态视图,具有友好的界面,视觉效果较好~
2025/2/21 8:54:28 12.22MB 动态效果
1
Unity水体涟漪动态效果。
适用与船,人等移动对象在水面的移动。
所产生的涟漪效果
2025/2/4 0:23:47 2.5MB Unity水
1
共 30 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡