zoukankan      html  css  js  c++  java
  • (转)VC中等比例缩放图像

    作者:Future Studio.徐景周
    版权所有:徐景周

      在放大或缩小图像时,如何能最好的保持图像原态比例来显示呢?下面提供一个涵数可帮你来实现,调用它后,返回的矩形区域既为最佳显示图像大小。
      涵数中的第一个参数rcScreen为图像要被显示的矩形大小,第二个参数sizePicture为图像自身大小,第三个参数bCenter为是否居中显示,返回值CRect既为图像最佳显示大小。
    涵数如下所示:

    CRect RectSizeWithConstantRatio( CRect* rcScreen,
    CSize sizePicture,
    BOOL bCenter)
    {
    CRect rect(rcScreen);
    double dWidth = rcScreen->Width();
    double dHeight = rcScreen->Height();
    double dAspectRatio = dWidth/dHeight;

    double dPictureWidth = sizePicture.cx;
    double dPictureHeight = sizePicture.cy;
    double dPictureAspectRatio = dPictureWidth/dPictureHeight;

    //If the aspect ratios are the same then the screen rectangle
    // will do, otherwise we need to calculate the new rectangle

    if (dPictureAspectRatio > dAspectRatio)
    {
    int nNewHeight = (int)(dWidth/dPictureWidth*dPictureHeight);
    int nCenteringFactor = (rcScreen->Height() - nNewHeight) / 2;
    rect.SetRect( 0,
    nCenteringFactor,
    (int)dWidth,
    nNewHeight + nCenteringFactor);

    }
    else if (dPictureAspectRatio < dAspectRatio)
    {
    int nNewWidth = (int)(dHeight/dPictureHeight*dPictureWidth);
    int nCenteringFactor = (rcScreen->Width() - nNewWidth) / 2;
    rect.SetRect( nCenteringFactor, 
    0,
    nNewWidth + nCenteringFactor,
    (int)(dHeight));
    }

    return rect;
    };
    ? 此涵数的使用方法如下:
    {
    ……(部分省略)
    //得到屏幕大小
    CRect rcScreen( 0, 0, 
    GetSystemMetrics(SM_CXSCREEN),
    GetSystemMetrics(SM_CYSCREEN));

    //得到图像尺寸
    CSize sizePicture(picture.m_Width, picture.m_Height); 

    CRect rcNewPictureRect = 
    SizeRectWithConstantAspectRatio(&rcScreen,
    sizePicture,
    TRUE);
    picture.Show(&dc, rcNewPictureRect);
    }

  • 相关阅读:
    input光标位置
    清除浮动
    CSS的两种盒模型
    网页中常用的命名
    清除inline-block元素默认间距
    自定义复选框样式及全选操作
    如何用elementui去实现图片上传和表单提交,用axios的post方法
    datatables
    9273:PKU2506Tiling
    666:放苹果
  • 原文地址:https://www.cnblogs.com/lebronjames/p/1946379.html
Copyright © 2011-2022 走看看