目录第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
辽宁省地图矢量PPT模板.pptx,pptfans网提供辽宁省地图矢量PPT模板下载,下载后你可以根据需要,修改不同的配色方案,也可根据不同的地区,填充不同的颜色或描边,以突出该区域。
地图模板通用性较广,无论你在产品
2025/6/25 7:11:01 105KB PPT模版
1
大眼仔旭给大家分享一款轻量级的图像处理工具。
HornilStylePixPro中文注册版是一个拥有许多先进功能的图形编辑程序。
Stylepix是“样式图片”缩写,这意味着你的图片具有一个良好的风格。
HornilStylePixPro中文版图像处理工具直观的用户界面可以减少您的时间工作,为了编辑图片更好更快!HornilStylePixPro1.14中文注册版HornilStylePixPro中文版-简介HornilStylePixPro是一个拥有许多先进功能的图形编辑程序。
Stylepix是“样式图片”缩写,这意味着你的图片具有一个良好的风格。
HornilStylePix具有一个直观的用户界面,它是为了让控制选择功能更加简单、方便而设计的,即使你没有经验,你也一样可以学会如何编辑图片和对你的照片进行润色。
总之,HornilStylePix直观的用户界面可以减少您的时间工作,为了编辑图片更好更快!HornilStylePix–功能介绍1.节省时间与直观的用户界面HornilStylePix具有直观的用户界面。
它的目的是调整所选功能简单,方便。
即使你没有经验,你可以轻松地学习如何编辑图像和修饰您的照片。
因此,HornilStylePix直观的用户界面减少您的时间工作.为了更好的速度编辑,HornilStylePix的设计重点在于轻,功能强大。
HornilStylePix运行在更少的资源,如网络,书籍和笔记本电脑或虚拟机的图像处理功能全(VMware公司虚拟框,虚拟pc等)的环境。
我们一直在努力提高HornilStylePix性能。
便携式支持HornilStylePix是一个轻量级的。
一种便携式版本的运行HornilStylePix从可移动存储设备如USB闪存驱动器,闪存卡,或软盘(媒体)。
要安装HornilStylePix便携式,只要下载便携包,然后解压缩。
要启动HornilStylePix便携,只需双击您的便携dirveStylePix.exe文件插图2.浏览图片和幻灯片浏览图像工具可以让你轻松地探索开放前的影像图像。
你也可以打开,复制,删除和重命名的图像或目录。
幻灯片显示了选择的图片系列是在当前工作的全屏幕模式路径中。
支持的文件格式:JPEG,PNG,GIF等,tif格式和TGA,BMP和旅行商。
3.方便的工作环境有多个文件可以同时打开工作。
打开的图像安排在MDI(多文档界面)的容器标签。
MDI的支持级联,瓷砖垂直,水平平铺,设置图标的安排。
快速的图像切换:画布窗口之间切换,按Ctrl+Tab键。
如果你想回去,按Ctrl+Shift+Tab键。
如果按上述键,切换窗口被弹出。
然后,如果你想选择下一个画布,按Tab键。
4.多层及分组支持层是用于HornilStylePix分开的画布不同的对象。
图层就像是在另一个堆放胶片。
每一层都可以有不同的对象。
HornilStylePix支持四个对象类型(图像,文本和路径形状)和组对象。
该组对象包含其他对象。
此外,本集团可能包含其他组。
您可以使用层管理层次。
HornilStylePix支持混合模式是用于确定如何两层互相融合。
在StylePix,您可以使用21种混合模式。
5.选择工具HornilStylePixPro中文版图像处理工具支持区域如以下选择工具:自动范围选择和色彩范围选择工具方形,圆形选取工具多边形,套索选择工具您可以通过上述工具的区域选择具有以下模式:新,加,减和相交。
现有的区域选择可以进行修改操作:边界,扩展,合同和柔软性。
6.50种实用的图像过滤器。
颜色调节过滤器:自动水平,自动对比度,自动颜色平衡,级别,曲线,色彩平衡,亮度/对比度,色相/饱和度,伽玛校正,去色,反转,灰度,阈值,量化,直方图均化,色调分离。
锐化和模糊过滤器像素化滤镜渲染过滤器噪声滤波器扭曲过滤器卷积过滤器风格过滤器形态滤波器照片增强过滤器7.绘图工具HornilStylePixPro中文版图像处理工具支持各种绘图工具如画笔,橡皮擦,直线,曲线,喷雾,克隆刷,洪水填充,渐变填充,路径和形状。
8.文字工具文本工具允许你在画布上键入文本。
在文本字符串可以被修改,不仅在正常状态,但也不失旋转对象属性的状态。
9.变换和对齐转换工具允许你改变选择区域或对象。
只有当区域选择启用存在。
当变换工具被激活,可以旋转和调整大小。
10.加强和还原工具在提高工具允许您提高基础上的图像变暗,躲闪,模糊和锐化工具。
11.裁剪工具作物工具用于作物或剪辑图像。
它适用于所有的形象,有形及无形的层面。
12.多
2025/6/24 6:44:44 19.09MB 图像处理工具
1
计算机图形学边界定义的8连通区域的种子填充算法计算机图形学边界定义的8连通区域的种子填充算法计算机图形学边界定义的8连通区域的种子填充算法
1
此次课程设计的课题为通过编程,实现圆和直线等基本图形的绘制。
要求用DDA算法、Bresenham算法和中点算法实现圆和直线等基本图形的绘制,并各自比较算法精度与效率的差别,实现二维图形的变换(包括平移,放缩,旋转,错切以及复合变换),用区域填充算法实现区域填充以及实现线段裁剪和多边形裁剪,并给出代码和结果截图。
2025/6/23 6:40:01 2.06MB DDA算法 Bresenham算法
1
第2章图形基础342.1笔和画刷342.1.1pen类342.1.2brush类352.2基本图形形状372.2.1点372.2.2直线和曲线372.2.3矩形、椭圆形和圆弧形402.2.4多边形422.3颜色442.4双倍缓存66第3章坐标系统和颜色变换693.1坐标系统693.2颜色变换77第二部分二维图形的基本算法第4章二维矩阵和变换824.1矩阵基础和变换824.2齐次坐标824.2.1齐次坐标中的缩放834.2.2齐次坐标中的平移834.2.3齐次坐标中的旋转844.2.4变换组合854.2.5c#中矩阵的定义864.2.6c#中的矩阵操作874.2.7c#中基本的矩阵变换894.3c#中图形对象的变换93基本变换934.4c#中的多对象变换1014.5文字变换105第5章二维线形图形1095.1序列化和反序列化及二维图形的基本框架1095.1.1c#序列化和反序列化1105.1.2二维图形的基本框架1135.2二维图形2485.2.1简单实例2485.2.2图例2785.2.3符号2895.2.4对数比例3025.2.5图形的修饰3085.3阶梯状图3165.4多y轴图318第6章特殊二维图形3276.1创建柱状图3276.1.1水平柱状图3276.1.2垂直柱状图3436.1.3图形充填柱状图3446.1.4重叠柱状图3466.2饼状图3486.3误差图3616.4股票图3676.4.1最高最低收盘价股票图3686.4.2最高最低开盘收盘价股票图3696.4.3最高最低价股票图3776.4.4k线图(阴阳烛图)3806.5面积图3896.6综合图390第三部分三维图形的相关知识及三维图形的实现第7章三维矩阵和变换3967.1三维数学概念3967.1.1操作三维对象3967.1.2数学结构3977.2三维中的基本矩阵和变换4027.2.1c#中三维点和矩阵的操作4037.2.2三维的基本变换4057.3方位角和仰角4347.4三维图形中的特殊坐标系统4397.4.1球坐标系统4407.4.2圆柱坐标系统4437.5特殊坐标中的实际应用4477.5.1球坐标示例4477.5.2双缓存463第8章三维图形4738.1三维图形基础4738.1.1point3和matrix3类4738.1.2chartstyle类4768.1.3坐标轴4968.1.4网格线4968.1.5标签4978.2三维折线图5038.3三维图形函数包5088.3.1chartstyle2d类5098.3.2point4类5158.3.3dataseries类5168.3.4chartfunctions类5218.3.5drawchart类5268.4曲面图的实现5418.4.1网格图5418.4.2幕布网格图5488.4.3瀑布网格图5518.4.4曲面图5538.5x-y平面色彩图5598.6轮廓图5648.6.1轮廓图的算法5648.6.2轮廓图的实现5648.7组合图5698.7.1三维体系中的x-y色彩图5708.7.2三维体系中的轮廓图5718.7.3网格-轮廓组合图5758.7.4曲面-轮廓组合图5768.7.5填充曲面-轮廓组合图5768.8三维柱状图577实现柱状图5778.9切片图591切片图的实现591第四部分c#中应用微软office的excel实现各种二维及三维图形第9章应用程序中的excel图表6009.1excel和c#间的互操作6009.2c#应用程序中的excel图表示例6029.2.1excel图表对象模型6029.2.2创建独立的excel图表6049.2.3创建嵌入式excel图表
2025/6/18 10:39:41 22.07MB C# 2D 3D 图形
1
在计算机视觉领域,图像配准是一项关键任务,它涉及到将多张图像对齐,以便进行比较、融合或分析。
OpenCV(开源计算机视觉库)提供了一系列工具和算法来执行这项工作,其中包括相位相关法。
本文将深入探讨如何利用OpenCV实现相位相关图像配准,并详细介绍相关知识点。
相位相关是一种非像素级对齐技术,它通过计算两个图像的频域相位差异来确定它们之间的位移。
这种方法基于傅里叶变换理论,傅里叶变换可以将图像从空间域转换到频率域,其中图像的高频成分对应于图像的边缘和细节,低频成分则对应于图像的整体结构。
我们需要理解OpenCV中的傅里叶变换过程。
在OpenCV中,可以使用`cv::dft`函数对图像进行离散傅里叶变换。
这个函数将输入的图像转换为频率域表示,结果是一个复数矩阵,包含了图像的所有频率成分。
然后,为了进行相位相关,我们需要计算两个图像的互相关。
这可以通过将一个图像的傅里叶变换与另一个图像的共轭傅里叶变换相乘,然后进行逆傅里叶变换得到。
在OpenCV中,可以使用`cv::mulSpectrums`函数来完成这个步骤,它实现了复数乘法,并且可以指定是否进行对位相加,这是计算互相关的必要条件。
接下来,我们获得的互相关图在中心位置有一个峰值,该峰值的位置对应于两幅图像的最佳位移。
通过找到这个峰值,我们可以确定图像的位移量。
通常,这可以通过寻找最大值或最小二乘解来实现。
OpenCV提供了`cv::minMaxLoc`函数,可以帮助找到这个峰值。
在实际应用中,可能会遇到噪声和图像不完全匹配的情况。
为了提高配准的准确性,可以采用滤波器(如高斯滤波器)预处理图像,降低噪声影响。
此外,还可以通过迭代或金字塔方法逐步细化位移估计,以实现亚像素级别的精度。
在实现过程中,需要注意以下几点:1.图像尺寸:为了进行傅里叶变换,通常需要将图像尺寸调整为2的幂,OpenCV的`cv::getOptimalDFTSize`函数可以帮助完成这一操作。
2.零填充:如果图像尺寸不是2的幂,OpenCV会在边缘添加零,以确保傅里叶变换的效率。
3.归一化:为了使相位相关结果更具可比性,通常需要对傅里叶变换结果进行归一化。
一旦得到配准参数,可以使用`cv::warpAffine`或`cv::remap`函数将一幅图像变换到另一幅图像的空间中,实现精确对齐。
总结来说,OpenCV提供的相位相关方法是图像配准的一种高效工具,尤其适用于寻找微小的位移。
通过理解和运用上述步骤,开发者可以在自己的项目中实现高质量的图像配准功能。
2025/6/17 6:37:22 204KB OpenCV 相位相关 图像配准
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
包含:3D简介矢量矩阵线性变换三维变换存储坐标实现矩阵系统实现三角法系统创建变换矩阵如何创建透视变换对象多边形填充多边形结构发现三角形绘制三角形隐面消除Dilemna底面消除Z-缓冲3D纹理映射三维明暗计算法向量计算叉乘使用光线表计算法向量
2025/6/6 7:39:04 92KB C&VC&C++ GIS技术文档 GIS教程
1
对于一些图片来说,经过处理后的图片可能会出现一些孔洞的现象,影响图像地美观性,或者检测一些裂纹,会出现裂纹不连续,甚至出现断裂地现象,影响图像的效果,该代码就是解决这些断裂现象,使得图像变得连续。
2025/5/30 21:42:30 3.65MB 图形处理 孔洞填充
1
共 325 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡