GDI+ 旋转图片(jpg,bmg,GDI+支持的图像格式)

本文介绍了一种使用 GDI+ 进行图片旋转的简单方法,通过在对话框的 OnPaint() 方法中直接编写代码来实现。该方法绕过了复杂的位图旋转过程,并提供了一个示例代码片段,展示如何在不同角度下显示图片。

为了做旋转图片,用了我太多的精力,位图旋转的实现实在是太麻烦了,直到前几天我看到了GDI+,才想出来了这个简单的旋转图像的方法,今天太累了,改天补充出来动画的旋转,希望各位同学一起分享!

在对话框做中的OnPaint()方法中直接写入复制代码就可以了,其他的旋转角度可以自己补充

void CgdiTestDlg::OnPaint()
{
 CPaintDC dc(this); // 用于绘制的设备上下文
 if (IsIconic())
 {

  SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);

  // 使图标在工作矩形中居中
  int cxIcon = GetSystemMetrics(SM_CXICON);
  int cyIcon = GetSystemMetrics(SM_CYICON);
  CRect rect;
  GetClientRect(&rect);
 // MessageBox(rect.Width());
  
  int x = (rect.Width() - cxIcon + 1) / 2;
  int y = (rect.Height() - cyIcon + 1) / 2;

  // 绘制图标
  dc.DrawIcon(x, y, m_hIcon);
 }
 else
 {
  CDialog::OnPaint();
 }
 Graphics graphics(dc.m_hDC);
 CBrush cbrush(RGB(0,0,255));
 
 Image image(_T("E:\\dyr\\dyr\\DSCF2741.JPG"));
 
 //正常的显示
     Point destPoints1[3] ={Point(10,10),Point(10,410),Point(310,10)};
 //旋转90度显示
 // Point destPoints1[3] ={Point(10,410),Point(10,10),Point(310,410)};


 
 graphics.DrawImage(&image,destPoints1,3);

 

//graph.DrawImage(&image,100,100);

//graph.RotateTransform(30.0f);

//graph.DrawImage(&image,200,200);

}

转载于:https://www.cnblogs.com/zhixing/archive/2011/03/21/1990666.html

以前一直不知道在GUI里面画出的图片可以旋转,所以遇到想要旋转图片时,都是把图片贴到一个面片上,旋转面片,很是不方便,最近发现在GUI里是可以旋转图片的,所以写到这里分享给大家。下面贴一个例子,利用图片旋转写的一个钟表的代码,不废话,直接上代码。   var Tu1 : Texture2D;   var Time1 : float = 0;   function FixedUpdate () {    Time1 += Time.deltaTime;   }   function OnGUI () {    GUI.Label(Rect(250,170,161,62),getTime(Time1));       GUIUtility.RotateAroundPivot (6*Time1, Vector2(103, 200));    GUI.DrawTexture(Rect(100,100,6,100),Tu1);//秒针    GUIUtility.RotateAroundPivot (-6*Time1, Vector2(103, 200));       GUIUtility.RotateAroundPivot (0.1*Time1, Vector2(103, 200));    GUI.DrawTexture(Rect(100,120,6,80),Tu1);//分针    GUIUtility.RotateAroundPivot (-0.1*Time1, Vector2(103, 200));       GUIUtility.RotateAroundPivot (0.1/60*Time1, Vector2(103, 200));    GUI.DrawTexture(Rect(100,140,6,60),Tu1);//时针    GUIUtility.RotateAroundPivot (-0.1/60*Time1, Vector2(103, 200));   }    function getTime(time : float) : String{    if(time<0){    return "00:00:00";    }    var lastTime : String = "";    var hour = Mathf.FloorToInt(time/3600$);    if(hour/10 >=1){    lastTime+="" + hour;    }else{    lastTime +="0" + hour;    }    var minute = Mathf.FloorToInt(time/60`);    if(minute/10 >=1){    lastTime+=":" + minute;    }else{    lastTime +=":0" + minute;    }    var second = Mathf.FloorToInt(time`);    if(second/10 >=1){    lastTime+=":" + second;    }else{    lastTime +=":0" + second;    }    return lastTime;   }   简单介绍一下代码   GUIUtility.RotateAroundPivot (6*Time1, Vector2(103, 200))旋转GUI的代码,第一个参数为旋转的角度,第二个参数为旋转的中心点,在它之下的GUI元素都会执行该旋转,例如图片、文字等。当你只想旋转某一GUI元素而其他元素不旋转事就得给它一个停止旋转的代码,很简单,停止旋转时给它一个反向的角度,ok。   为了便于测试,在钟表左边给出一个数字时间经行对比。getTime(time : float)可用于实现场景中时间的显示,或者倒计时的显示等,需要的直接拿走,哈哈哈~
内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值