В новом проекте EXE бросьте на форму пару лабелей.
Проект - Форма(Кот)[source]Option Explicit
Private m_ScaleX As Long
Private m_ScaleY As Long
Private m_hdc As Long
Private m_hwnd As Long
Private m_hTheme As Long
Private c_hFont As Long
Private m_hFont As Long
Private m_lFontSize As Long
Private Type MARGINS
Left As Long
Right As Long
Top As Long
Bottom As Long
End Type
Private Type RECT
Left As Long
Top As Long
Right As Long
Bottom As Long
End Type
Private Type POINTAPI
X As Long
Y As Long
End Type
Private Type BITMAPINFOHEADER
biSize As Long
biWidth As Long
biHeight As Long
biPlanes As Integer
biBitCount As Integer
biCompression As Long
biSizeImage As Long
biXPelsPerMeter As Long
biYPelsPerMeter As Long
biClrUsed As Long
biClrImportant As Long
End Type
Private Type RGBQUAD
rgbBlue As Byte
rgbGreen As Byte
rgbRed As Byte
rgbReserved As Byte
End Type
Private Type BITMAPINFO
bmiHeader As BITMAPINFOHEADER
bmiColors As RGBQUAD
End Type
Private Type DTTOPTS
dwSize As Long
dwFlags As Long
crText As Long
crBorder As Long
crShadow As Long
eTextShadowType As Long
ptShadowOffset As POINTAPI
iBorderSize As Long
iFontPropId As Long
iColorPropId As Long
iStateId As Long
fApplyOverlay As Long
iGlowSize As Long
End Type
Private Type LOGFONT
lfHeight As Long
lfWidth As Long
lfEscapement As Long
lfOrientation As Long
lfWeight As Long
lfItalic As Byte
lfUnderline As Byte
lfStrikeOut As Byte
lfCharSet As Byte
lfOutPrecision As Byte
lfClipPrecision As Byte
lfQuality As Byte
lfPitchAndFamily As Byte
lfFaceName(31) As Byte
End Type
Private Type NONCLIENTMETRICS
cbSize As Long
iBorderWidth As Long
iScrollWidth As Long
iScrollHeight As Long
iCaptionWidth As Long
iCaptionHeight As Long
lfCaptionFont As LOGFONT
iSMCaptionWidth As Long
iSMCaptionHeight As Long
lfSMCaptionFont As LOGFONT
iMenuWidth As Long
iMenuHeight As Long
lfMenuFont As LOGFONT
lfStatusFont As LOGFONT
lfMessageFont As LOGFONT
End Type
Private Declare Function DwmExtendFrameIntoClientArea Lib "dwmapi.dll" (ByVal hWnd As Long, margin As MARGINS) As Long
Private Declare Function DwmIsCompositionEnabled Lib "dwmapi" (ByRef pfEnabled As Long) As Long
Private Declare Function GetClientRect Lib "user32" (ByVal hWnd As Long, lpRect As RECT) As Long
Private Declare Function FillRect Lib "user32" (ByVal hDC As Long, lpRect As RECT, ByVal hBrush As Long) As Long
Private Declare Function GetDC Lib "user32" (ByVal hWnd As Long) As Long
Private Declare Function ReleaseDC Lib "user32" (ByVal hWnd As Long, ByVal hDC As Long) As Long
Private Declare Function SystemParametersInfo Lib "user32" Alias "SystemParametersInfoA" (ByVal uAction As Long, ByVal uParam As Long, ByRef lpvParam As NONCLIENTMETRICS, ByVal fuWinIni As Long) As Long
Private Declare Function CreateSolidBrush Lib "gdi32" (ByVal crColor As Long) As Long
Private Declare Function SelectObject Lib "gdi32" (ByVal hDC As Long, ByVal hObject As Long) As Long
Private Declare Function DeleteObject Lib "gdi32" (ByVal hObject As Long) As Long
Private Declare Function CreateCompatibleDC Lib "gdi32" (ByVal hDC As Long) As Long
Private Declare Function CreateDIBSection Lib "gdi32" (ByVal hDC As Long, ByRef pBitmapInfo As BITMAPINFO, ByVal un As Long, ByVal lplpVoid As Long, ByVal handle As Long, ByVal dw As Long) As Long
Private Declare Function BitBlt Lib "gdi32" (ByVal hDestDC As Long, ByVal X As Long, ByVal Y As Long, ByVal nWidth As Long, ByVal nHeight As Long, ByVal hSrcDC As Long, ByVal xSrc As Long, ByVal ySrc As Long, ByVal dwRop As Long) As Long
Private Declare Function DeleteDC Lib "gdi32" (ByVal hDC As Long) As Long
Private Declare Function CreateFontIndirect Lib "gdi32" Alias "CreateFontIndirectA" (ByRef lpLogFont As LOGFONT) As Long
Private Declare Function OpenThemeData Lib "uxtheme" (ByVal hWnd As Long, ByVal pszClassList As String) As Long
Private Declare Function CloseThemeData Lib "uxtheme" (ByVal hTheme As Long) As Long
Private Declare Function DrawThemeTextEx Lib "uxtheme" (ByVal hTheme As Long, ByVal hDC As Long, ByVal iPartId As Long, _
ByVal iStateId As Long, ByVal pszText As String, ByVal iCharCount As Long, ByVal dwFlags As Long, pRect As RECT, pOptions As DTTOPTS) As Long
Private sText As String
Private Glass As Boolean
Private Sub Form_Load()
Dim lEnabled As Long
Dim X As Long
Dim F As String
Dim mg As MARGINS
Dim lpFont As LOGFONT
Dim ncm As NONCLIENTMETRICS
sText = "Aero Glass фифект"
m_hdc = hDC
Glass = Len(Environ$("LOCALAPPDATA")) > 0 'верный признак Vista и Windows 7
If Glass Then
With Screen
m_ScaleX = .TwipsPerPixelX
m_ScaleY = .TwipsPerPixelY
End With
With Me
m_hwnd = .hWnd
m_hTheme = OpenThemeData(.hWnd, StrConv("Window", vbUnicode))
End With
With mg
.Left = -1
.Right = -1
.Top = -1
.Bottom = -1
End With
With ncm
.cbSize = Len(ncm)
Call SystemParametersInfo(SPI_GETNONCLIENTMETRICS, Len(ncm), ncm, 0)
lpFont = .lfMessageFont
End With
With lpFont
.lfWeight = 500
.lfHeight = .lfHeight * 1.2
m_lFontSize = -.lfHeight
.lfQuality = CLEARTYPE_QUALITY
End With
m_hFont = CreateFontIndirect(lpFont)
With lpFont
.lfWeight = 500
.lfHeight = .lfHeight * 1.3
m_lFontSize = -.lfHeight
.lfQuality = CLEARTYPE_QUALITY
For X = 0 To 8
.lfFaceName(X) = Asc(Mid$("Wingdings", X + 1, 1))
Next
For X = 9 To 31
.lfFaceName(X) = 0
Next
End With
c_hFont = CreateFontIndirect(lpFont)
Call DwmIsCompositionEnabled(lEnabled)
If (lEnabled) Then Call DwmExtendFrameIntoClientArea(m_hwnd, mg)
Label1.Visible = False
Label2.Visible = False
Else
With Label1
.Enabled = False
.Height = 255
.Width = 780
.Left = ScaleWidth - 1015
.Top = ScaleHeight - 300
.Font.Name = "Wingdings"
.Font.Size = 13
.Font.Bold = True
.Caption = "ю Ь"
.Visible = True
End With
With Label2
.Alignment = vbCenter
.Enabled = False
.Height = 615
.Width = 2580
.Left = 480
.Top = 1200
.Font.Name = "Tahoma"
.Font.Size = 12
.Caption = sText & vbCr & " не работает !!!"
.Visible = True
End With
End If
End Sub
Private Sub Form_MouseDown(Button As Integer, Shift As Integer, X As Single, Y As Single)
If Y > 2870 And Y < 3160 Then
If X > 3000 And X < 3230 Then MsgBox "Go"
If X > 2460 And X < 2760 Then MsgBox "Check"
End If
End Sub
Private Sub Form_Paint()
Dim obj As Long
Dim hOld As Long
Dim lpRect As RECT
If Glass Then
obj = CreateSolidBrush(RGB(0, 0, 0))
hOld = SelectObject(m_hdc, obj)
GetClientRect m_hwnd, lpRect
FillRect m_hdc, lpRect, obj
SelectObject m_hdc, hOld
DeleteObject obj
Call DrawGlassEffect(lpRect)
End If
End Sub
Private Sub Form_Unload(Cancel As Integer)
If Glass Then
If m_hTheme Then CloseThemeData (m_hTheme)
If m_hFont Then DeleteObject (m_hFont)
End If
End Sub
Private Sub DrawGlassEffect(lpRect As RECT)
Dim bm As Long
Dim hOld As Long
Dim handle As Long
Dim dib As BITMAPINFO
Dim dto As DTTOPTS
handle = CreateCompatibleDC(m_hdc)
With dib.bmiHeader
.biSize = 40
.biWidth = 50 * m_ScaleX
.biHeight = -m_lFontSize * m_ScaleY
.biPlanes = 1
.biBitCount = 32
.biCompression = BI_RGB
End With
With dto
.dwSize = Len(dto)
.dwFlags = DTT_GLOWSIZE Or DTT_COMPOSITED
.iGlowSize = 10
End With
bm = CreateDIBSection(m_hdc, dib, DIB_RGB_COLORS, 0, 0, 0)
hOld = SelectObject(handle, bm)
Call SelectObject(handle, m_hFont)
Call DrawThemeTextEx(m_hTheme, handle, 0, 0, StrConv(sText, vbUnicode), -1, DT_SINGLELINE Or DT_CENTER Or DT_VCENTER Or DT_NOPREFIX, lpRect, dto)
Call SelectObject(handle, c_hFont)
Call DrawThemeTextEx(m_hTheme, handle, 0, 0, StrConv("ю Ь ", vbUnicode), -1, DT_SINGLELINE Or DT_RIGHT Or DT_BOTTOM Or DT_NOPREFIX, lpRect, dto)
Call BitBlt(m_hdc, 0, 0, 50 * m_ScaleX, m_lFontSize * m_ScaleY, handle, 0, 0, vbSrcCopy)
Call SelectObject(handle, hOld)
DeleteObject bm
DeleteDC handle
End Sub[/source]
Пример выдран из рабочей программы, поэтому попрошу не ругаться на кучу лишнего хлама в коде, он может пригодится ...
PublicSharedFunction DwmExtendFrameIntoClientArea(ByVal hwnd As IntPtr, ByRef MARGINS As MARGINS) AsInteger
EndFunction
Это другое. Вы здесь парите васю с отступами по бокам, сверху и снизу, а у него код сплошняком покрывает все окно плюс он подрубил васю для работы с текстом с ореолом. Не надо пытаться сделать вид, что, мол, на .NET это будет всего 20 строчек.
PS: Я вот это еще очень хочу в класс обернуть (можно и на дотнете), чтоб вообще было по оццоффски - а-ля для стеклопечати используем Print, для задания стеклянных областей просто используем некую "стеклянную" кисть. Будет вообще супер Кстати, а там от SolidBrush можно класс унаследовать и перегрузить все его члены? Ну чтоб действительно стеклокисточку получить?
Кстати в моем коде есть лажа, не выставляется размер окна, от этого зависит работа импровизированных кнопочек в нижнем углу.
VВD не буянь, пусть дотнэтчики себя пробуют в программировании АПИ, может чему научатся , есть время небольшой алго переписать?
Winаnd, я в плеере не смотрел, может VBD возьмется, я свой алго знаю и так быстрее въеду, чем ковырять, вникать в чужой код.
UU, я недавно один примерчик Павлу в ящик на митуе кинул, ты не в курсе?
Автор я , пример того как можно взять 32х32х32 иконку экзешника и как есть назначить её форме, для свисты и семерки актуальное украшение.
Может есть смысл его выложить в Примерах?
Smith, ну если ты не можешь в банальном маленьком modSpectrum.bas разобрацо, то я уж не знааю) Покури инфу о SetDIBitsToDevice в таком случае.
что за иконка? в смысле примерчик, как 32битовую иконку приделать?
Winаnd, а сказал, что немогу разобраться???
Мне просто лень, ну раз ты говоришь, что всё так банально, то гляну конечно, спасибо.
Я не встречал машин с измененными переменными среды, разве что тэмп переназначают в другое место и свои добавляют иногда.
Не уверен в методе, не используй, вобще делай как хочешь, например можно тупо обработать ошибку.
Тыж знаешь вб6 берет максимум 24 битные иконы для форм, а редактор ресурсов берет и того меньше, 8 бит.
Вот и приходится сторонним редактором ресурсов заменять иконки в экзешнике.
Вобщем в хрюнделе хватало заменить икону экзешника, менялась картина в окне Альт+Таб, проводнике и диспетчере задач, тока в углу формы и в панели задач оставалась убогая 8/24 битная.
А в висте и семерке Альт+Таб, диспетчер задач и панель задач показывают тока маленькую страшненькую икону формы.
Вылечить прогу можно элементарно, тремя апишками, семью строчками кода.
Smith, я в курсе, что можешь разобраться. Создаешь палитру, заполняешь массив цветами палитры, фигачишь на экран через SetDIBitsToDevice
.Переменные среды - не главное. Как-то проверяется досупность аэро? вот здесь что ли DwmIsCompositionEnabled?
.Раскрой тайну Семи Строк Кода)
Smith, гружу 32х32(32) из ico-файла. Если закомментить Form1.Icon = Nothing, то ничего не меняется вообще, а если оставить, то ощущение, что оно резайзится до 16х16, а потом попадает в панель задач и растягивается обратно