C# pictureBox显示图像 自动调整大小 缩放自适应 画图位置自适应

本文介绍如何使用C#的pictureBox控件实现图片自动缩放和位置调整,包括设置PictureBoxSizeMode.StretchImage和ImageLayout.Stretch,以及自定义图像显示大小和位置的计算方法。同时涵盖了在pictureBox上进行画图的技巧,如适应性和行间距设置。

VS-C++ 系列:所有相关C++文章链接.
VS-C# 系列:所有相关C#文章链接.
bat 系列:所有相关bat文章链接.
OpenCV 系列:所有相关OpenCV文章链接.


AD 系列:所有相关文章链接
Keil 系列:所有相关文章链接
Arduino 系列:所有相关Arduino文章链接


Git SVN 系列:所有相关Git SVN文章链接


Linux 系列:所有相关文章链接


python 系列:所有相关文章链接
Raspberry Pi Pico 系列:所有相关文章链接


所有内容均以最小系统调试成功;逐步提供低分源码工程下载
保证每行代码都经过验证!
如有疑惑,欢迎留言,看见即回;祝好__by Dxg_LC

序言:
1、以上链接为方便整理查看资料用;伴随博文发布更新,如果有不正确处,感谢指正
2、因本人能力有限若有不正确之处或者相关超链接失效,请于相关文章内提醒@博主;灰常感谢
3、友情提醒1,勿要《一支烟 + 一杯茶 == 一坐一下午》 身体重要,革命本钱;
4、友情提醒2,多喝热水;
5、友情提醒3,听媳妇话+多点时间陪家人;
在这里插入图片描述

C# pictureBox显示图像 自动调整大小 缩放自适应 画图位置自适应

/// <summary>
/// 加载的图像变量
/// </summary>
Image img;
public Form1()
{
	//把图像的缩放交给 pictureBox 自行调整
	pictureBox1.SizeMode = PictureBoxSizeMode.StretchImage;
	pictureBox1.BackgroundImageLayout = ImageLayout.Stretch;
}


double pfRatio = 0.0;//重要的参数;作图 自适应就靠它了
private void button1_Click(object sender, EventArgs e)
{
	img = Image.FromFile("1.jpg");
	pictureBox1.BackgroundImage = img;
	//pictureBox1 最大的显示范围
	int preW = 500;
	int preH = 1000;

	if ((double)preW / img.Width > (double)preH / img.Height)
	{
		pfRatio = (double)preH / img.Height;
		pictureBox1.Size = new Size((int)(img.Width * pfRatio), preH);
	}
	else
	{
		pfRatio = (double)preW / img.Width;
		pictureBox1.Size = new Size(preW, (int)(img.Height * pfRatio));
	}
	pictureBox1.Invalidate();
}
/*如果有在pictureBox1上作图,那也跟随调整位置和参数*/
//画str的数量
int StrShowCount = 0;
//画str的行间距
int StrShowInterval = 13;
private void pictureBox1_Paint(object sender, PaintEventArgs e)
{
	int r = 2;
    int penW = 2;
	StrShowCount = 0;
	
	Graphics g = e.Graphics;
	g.DrawString("HF,GG GL", Font, Brushes.Beige, new Point(0, (StrShowCount++) * StrShowInterval));
	g.DrawString("1.jpg", Font, Brushes.Beige, new Point(0, (StrShowCount++) * StrShowInterval));

	g.DrawEllipse(new Pen(Brushes.Beige, penW), new Rectangle(new Point((int)(200 * pfRatio) - r, (int)(200 * pfRatio) - r), new Size(r * 2, r * 2)));
}



Dxg-原创出品,如需转载,请注明出处;

欢迎收藏,点赞;"一键三联"走起,LOL
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

淘气坏坏besos

原创干货分析,欢迎大佬打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值