【每日一发】DELPHI位图文件的裁剪和伸缩操作

    在工作中有用到缩略图展示,这个时候就需要对图片进行伸缩处理,也有时候会遇到需要裁剪部分区域,比如正中间的部分,通过在网上查阅资料,发现通过Windows的两个API就可以很方便的搞定。

    先贴下代码:

   

procedure FitBitmap(const Source,Dest:string;const x,y:integer;const ColorBit:TPixelFormat);
var
  abmp,bbmp:tbitmap;
  scalex,scaley:real;
begin
  abmp:=tbitmap.Create;
  bbmp:=tbitmap.Create;
  try
    abmp.LoadFromFile(Source);
    scaley := abmp.Height / y;
    scalex := abmp.Width / x;
    bbmp.Width := round(abmp.Width / scalex);
    bbmp.Height := round(abmp.Height / scaley);
    bbmp.PixelFormat := pf8bit;
    SetStretchBltMode(bbmp.Canvas.Handle, COLORONCOLOR);
    stretchblt(bbmp.Canvas.Handle, 0, 0, bbmp.Width, bbmp.Height, abmp.Canvas.Handle, 0, 0, abmp.Width, abmp.Height, srccopy);
    bbmp.SaveToFile(Dest);
  finally
    abmp.Free;
    bbmp.Free;
  end;
end;

从上面的代码可以看到,主要用到两个API:

SetStretchBltMode

stretchblt

其中真正发挥作用的是第二个,可以实现图片的伸缩和裁剪,伸缩和裁剪的区别主要在于原始位图的取图的区域。这个函数的参数很多,但是分为了三个部分:

1 目标位图:

     分别制定了位图画布的句柄

     开始画图的 TopeLeft属性

     画图矩形的宽和高

2 原始位图部分:

    原始位图画布的句柄

    原始画布的TopeLeft属性

    原始画布区域的宽和高

3 模式 


想要裁剪图片就需要修改原始位图部分的参数即可。


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在VS2015中使用Qt插件实现HTTP服务器和HTTP客户端通信可以通过Qt网络模块来实现,这个模块提供了双向通信的网络功能。首先我们需要安装Qt VS Tools插件,然后在Visual Studio安装路径下的Qt5目录中找到msvc2015_64目录,将它添加到Visual Studio的Qt项目中。接下来,我们需要使用Qt网络模块来实现HTTP服务器和HTTP客户端的通信。 对于HTTP服务器,可以创建一个继承自QTcpServer的类,并重写incomingConnection方法,在这个方法中接收HTTP请求,并发送HTTP响应。对于HTTP客户端,可以创建一个继承自QNetworkAccessManager的类,并使用它提供的方法发送HTTP请求,接收HTTP响应。 具体实现中,我们可以在QTcpServer类的构造函数中调用listen方法来监听指定的服务器端口,接收客户端连接。在incomingConnection方法中,我们可以使用QTcpSocket来接收HTTP请求,然后解析请求中的路径和参数。接着,我们可以根据请求中的路径,处理对应的业务逻辑,并构造HTTP响应。最后,使用QTcpSocket类的write方法将HTTP响应发送给客户端。对于HTTP客户端,我们可以使用QNetworkAccessManager类的get或post方法发送HTTP请求,并使用QNetworkReply类接收HTTP响应。在接收HTTP响应时,我们可以使用QNetworkReply类的readAll方法将HTTP响应读取出来,并处理其中的数据。 综上所述,在VS2015中使用Qt插件实现HTTP服务器和HTTP客户端的通信,需要借助Qt网络模块来实现,在具体实现中要注意处理HTTP请求和响应的逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值