当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 将一个图片按比例缩放显示在一个Frame中

ASP.NET
使用函数传递参数来执行相应的数据库操作
如何实现在窗体和窗体之间进行传递数据
ASP.NET中文显示之两种解决方法
ASP.NET、JSP及PHP之间的抉择
ASP.NET 2.0发送电子邮件中存在的问题
谈谈HtmlControl与WebControl的区别与用途
从ASP.NET 1.1升级到ASP.NET 2.0要考虑的Cookie问题
通过系统配置来提高ASP.NET应用程序的稳定性
妙用ASP2.0中的URL映射改变网址
AJAX实现web页面中级联菜单的设计
ASP.NET跨页面传值技巧总结
再议ASP.NET DataGrid控件中的“添加新行”功能
Geometry 对象浅析
重构CollapsibleSplitter
如何利用.NET Framework使用RSS feed
ASP.NET获取IP与MAC地址的方法
在ASP.NET 2.0中使用样式、主题和皮肤
ASP.NET中为GridView添加删除提示框
ASP.NET 2.0,无刷新页面新境界
看看一个.net版对话框控件

ASP.NET 中的 将一个图片按比例缩放显示在一个Frame中


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 34 ::
收藏到网摘: n/a

 

代码如下:

以下为引用的内容:

  'Form1.frm
  VERSION 5.00
  Object = "{F9043C88-F6F2-101A-A3C9-08002B2F49FB}#1.2#0"; "COMDLG32.OCX"
  Begin VB.Form Form1
  Caption = "Form1"
  ClientHeight = 5010
  ClientLeft = 60
  ClientTop = 345
  ClientWidth = 7800
  LinkTopic = "Form1"
  ScaleHeight = 334
  ScaleMode = 3 'Pixel
  ScaleWidth = 520
  StartUpPosition = 3 '窗口缺省
  Begin MSComDlg.CommonDialog CommonDialog1
  Left = 4635
  Top = 3120
  _ExtentX = 847
  _ExtentY = 847
  _Version = 393216
  End
  Begin VB.Frame Frame1
  Caption = "Frame1"
  Height = 3000
  Left = 4500
  TabIndex = 2
  Top = 30
  Width = 3180
  Begin VB.PictureBox Picture2
  Appearance = 0 'Flat
  ForeColor = &H80000008&
  Height = 2625
  Left = 120
  ScaleHeight = 173
  ScaleMode = 3 'Pixel
  ScaleWidth = 194
  TabIndex = 3
  Top = 255
  Width = 2940
  Begin VB.Image Image1
  Height = 1575
  Left = 465
  Top = 390
  Width = 1965
  End
  End
  End
  Begin VB.CommandButton Command1
  Caption = "&Load Picture"
  Height = 330
  Left = 5400
  TabIndex = 0
  Top = 3150
  Width = 1425
  End
  Begin VB.PictureBox Picture1
  Appearance = 0 'Flat
  AutoSize = -1 'True
  BorderStyle = 0 'None
  ForeColor = &H80000008&
  Height = 4425
  Left = 60
  ScaleHeight = 4425
  ScaleWidth = 4380
  TabIndex = 1
  Top = 105
  Width = 4380
  End
  End
  Attribute VB_Name = "Form1"
  Attribute VB_GlobalNameSpace = False
  Attribute VB_Creatable = False
  Attribute VB_PredeclaredId = True
  Attribute VB_Exposed = False
  Option Explicit
  
  Dim ReturnHeight As Long, ReturnWidth As Long
  
  Private Sub Command1_Click()
  Dim BigWidth As Long, BigHeight As Long
  Dim StretchWidth As Long, StretchHeight As Long
  CommonDialog1.Filter = "jpeg文件|*.jpg|gif文件|*.gif|所有文件|*.*"
  CommonDialog1.ShowOpen
  If CommonDialog1.FileName <> "" Then
  Picture1.Picture = LoadPicture(CommonDialog1.FileName)
  
  BigWidth = Picture1.Width
  BigHeight = Picture1.Height
  StretchWidth = Picture2.ScaleWidth
  StretchHeight = Picture2.ScaleHeight
  
  StretchImage BigWidth, BigHeight, StretchWidth, StretchHeight, True
  
  Image1.Stretch = True
  Image1.Width = ReturnWidth
  Image1.Height = ReturnHeight
  
  Image1.Left = (Picture2.ScaleWidth - Image1.Width) / 2
  Image1.Top = (Picture2.ScaleHeight - Image1.Height) / 2
  Image1.Picture = LoadPicture(CommonDialog1.FileName)
  End If
  End Sub
  
  Private Sub StretchImage(OriginalWidth As Long, OriginalHeight As Long, StretchWidth As Long, StretchHeight As Long, Optional Flag As Boolean = False)
  If (OriginalWidth >= StretchWidth Or OriginalHeight > StretchHeight) Or Flag = True Then '需要缩放
  If OriginalWidth / OriginalHeight >= StretchWidth / StretchHeight Then
  ReturnWidth = StretchWidth
  ReturnHeight = StretchWidth / OriginalWidth * OriginalHeight
  Else
  ReturnHeight = StretchHeight
  ReturnWidth = StretchHeight / OriginalHeight * OriginalWidth
  End If
  Else
  ReturnHeight = OriginalHeight
  ReturnWidth = OriginalWidth
  End If
  End Sub