很多人在開發手機應用程式時都會認為表單是固定尺寸無法變動,接著一定會有人說在編輯器裡面有Form1 屬性視窗有size 可以設定呀,就會變更大小啦看官們你可以試看看設定在跑一下因該是沒辦法變成跟我下圖所示一樣,所以接著要教大家如何來變更表單。
原本表單 變更表單
data:image/s3,"s3://crabby-images/b1609/b16098ce5eb2f13ab400816c74a3e33f59af0cd7" alt="image image"
Step1:開啟vs2008 新增一個vb 智慧型裝置專案,在表單上產一個按鍵 Resize
data:image/s3,"s3://crabby-images/e723a/e723a4703ec9b410c1363d27d546d308419140bc" alt="image image"
Step2:撰寫Form1程式碼
data:image/s3,"s3://crabby-images/4e083/4e083420da3c654ef1864b54dc34c6ff578f43e9" alt=""
data:image/s3,"s3://crabby-images/951a9/951a9c99c3e9d473288a3a429857325952eefdb7" alt=""
Imports ...System.Runtime.InteropServices
Public Class Form1
Private FormSize
As Size
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
<DllImport(
"coredll")> _
data:image/s3,"s3://crabby-images/951a9/951a9c99c3e9d473288a3a429857325952eefdb7" alt=""
Public Shared Function MoveWindow() Shared Function MoveWindow(ByVal hWnd As IntPtr, ByVal X As Integer, ByVal Y As Integer, ByVal Width As Integer, ByVal Height As Integer, ByVal Repaint As Boolean) As IntPtr
End Function data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
<DllImport(
"coredll")> _
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
Public Shared Function GetWindowLong() Shared Function GetWindowLong(ByVal hWnd As IntPtr, ByVal nItem As Integer) As Integer
End Function data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
<DllImport(
"coredll")> _
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
Public Shared Sub SetWindowLong() Shared Sub SetWindowLong(ByVal hWnd As IntPtr, ByVal nItem As Integer, ByVal nValue As Integer)
End Sub data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
<DllImport(
"coredll")> _
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
Public Shared Function GetCapture() Shared Function GetCapture() As IntPtr
End Function
Private Const GWL_STYLE
As Integer = -16
Private Const WS_CAPTION
As Integer = &HC00000
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
Private Sub Button1_Click() Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
'設定變更表單新尺寸
FormSize = New Size(200, 200)
'執行變更表單
ResizeForm()
End Sub data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
Private Sub ResizeForm() Sub ResizeForm()
'呼叫外部dll提供api來執行我們要的效果
Dim x, y As Integer
x = (Screen.PrimaryScreen.WorkingArea.Width - FormSize.Width) / 2
y = (Screen.PrimaryScreen.WorkingArea.Height - FormSize.Height) / 2 + Screen.PrimaryScreen.WorkingArea.Top
Me.Capture = True
Dim hWnd As IntPtr = GetCapture()
Me.Capture = False
SetWindowLong(hWnd, GWL_STYLE, GetWindowLong(hWnd, GWL_STYLE) Or WS_CAPTION)
MoveWindow(hWnd, x, y, FormSize.Width, FormSize.Height, True)
End Sub
End Class
Step3:將滑鼠移到功能表按下偵錯\開始偵錯部署應用程式
data:image/s3,"s3://crabby-images/7f4d0/7f4d021f635395cafaa1b26c633bae25d8adb759" alt="image image"
Step4:按下Resize 鍵,這時候看一下表單是否有變化
data:image/s3,"s3://crabby-images/5ea2a/5ea2ad2cadc870b164f3fac1dec5ce5e8fe04dad" alt="image image"
Step5: 源碼下載