我在JS Carousel中显示图像。图像非常大,所以我在HTML中缩小它们。我做一些数学来保持纵横比。最终,虽然那些大图像质量下降。应该注意这些图像已经存在于服务器中,我不应该更改原始文件的大小。
导致质量下降的原因是什么?我应该坚持使用较小尺寸的图像,增加最终尺寸吗?这是帮助的代码,最大宽度和高度分别为270和180。所有这些都是C#。
// srcccccc is the image file. Can be any kind of extension jpg, png, etc.
if (srcccccc != "")
{
Globals.NavigateURL();
string path = PortalSettings.HomeDirectory + srcccccc;
using (System.Drawing.Image img = System.Drawing.Image.FromFile(@Server.MapPath(path)))
{
int[] newSizes = ResizeWithRatio(img);
contentsall += "<img src=\"" + PortalSettings.HomeDirectory + srcccccc + "\" alt=\"Image "
+ folderidddin + "\" height=\"" + newSizes[1] + "px\"" + "\" width=\"" + newSizes[0] + "px\" />";
}
}
// HTML is dynamically added later....
private int[] ResizeWithRatio(System.Drawing.Image img)
{
int[] sizes = new int[2];
if (img.Width > maxWidth || img.Height > maxHeight)
{
float ri = (float)img.Width / (float)img.Height;
float rs = (float)maxWidth / (float)maxHeight;
if (rs > ri)
{
sizes[0] = (int)((float)img.Width * (float)maxHeight / (float)img.Height);
sizes[1] = maxHeight;
}
else
{
sizes[0] = maxWidth;
sizes[1] = (int)((float)img.Height * (float)maxWidth / (float)img.Width);
}
}
else
{
sizes[0] = img.Width;
sizes[1] = img.Height;
}
return sizes;
}
答案 0 :(得分:3)
您遇到的问题是您根本没有缩放图像,而是告诉Web浏览器拍摄完整尺寸的图像并将其渲染得更小。令人遗憾的是,浏览器并不是很擅长,我认为只需使用一种非常简单的算法即可。
解决方案是缩放服务器上的图像。我建议有一个页面处理程序以某种方式接收图像引用(文件名,id等)并在输出到客户端之前进行大小调整。以下问题涉及c#中的缩放。
答案 1 :(得分:1)
最好缩小图像服务器端have a look at this documentation。这将节省网络流量并创建更高质量的图片。