Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 Аватар для Argus19
1427 / 444 / 78
Регистрация: 24.09.2017
Сообщений: 2,525
Записей в блоге: 22

Цвета Picture Box

17.05.2020, 16:00. Показов 583. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
сделал цвета формы и Picture Box = vbTransparent. Прозрачным, как ожидалось, ничто не стало. Почему, заголовок формы прозрачен, а остальное нет?
Миниатюры
Цвета Picture Box  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
17.05.2020, 16:00
Ответы с готовыми решениями:

Можно ли динамически создавать Picture Box внутри другого Picture Box?
Можно ли динамически создавать Picture Box внутри другого Picture Box. Если можно то как? Заранее благодарен

Инструмент рука в Picture Box
Возникла задача сделать такой инструмент. Есть Picture Box в котором рисуется график функции, хочу увеличивать картинку и рассматривать в...

Разместить IPictureDisp в Picture Box с координатами
Public TempPic As IPictureDisp Set TempPic = LoadPicture(FileName) У объекта IPictureDisp нет свойства Picture поэтому, метод...

10
 Аватар для Pro_grammer
6807 / 2839 / 527
Регистрация: 24.04.2011
Сообщений: 5,308
Записей в блоге: 10
17.05.2020, 17:01
Цитата Сообщение от Argus19 Посмотреть сообщение
заголовок формы прозрачен, а остальное нет
Прозрачность заголовка зависит от стиля настройки Винды.
Остальное вам самому надо:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
Option Explicit
 
Const LWA_COLORKEY = 1
Const LWA_ALPHA = 2
Const LWA_BOTH = 3
Const WS_EX_LAYERED = &H80000
Const GWL_EXSTYLE = -20
 
Private Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hWnd As Long, ByVal color As Long, ByVal x As Byte, ByVal alpha As Long) As Boolean
Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hWnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hWnd As Long, ByVal nIndex As Long) As Long
Private Declare Function WindowFromPoint Lib "user32" (ByVal xPoint As Long, ByVal yPoint As Long) As Long
Private Declare Function GetCursorPos Lib "user32" (lpPoint As POINTAPI) As Long
 
Private Type POINTAPI
        x As Long
        y As Long
End Type
 
Private pPoint As POINTAPI
Private hMouseOverWnd As Long
Public Trans As Integer
 
Public Function SetTrans(hWnd As Long, Trans As Integer)
 
    Dim Tcall As Long
 
    If Trans <= 0 Then
        Exit Function
    Else
        Tcall = GetWindowLong(hWnd, GWL_EXSTYLE)
        SetWindowLong hWnd, GWL_EXSTYLE, Tcall Or WS_EX_LAYERED
        SetLayeredWindowAttributes hWnd, RGB(255, 255, 0), Trans, LWA_ALPHA
    End If
 
End Function
 
Private Sub Form_Load()
SetTrans Form1.hWnd, 120
End Sub
1
Модератор
10048 / 3894 / 883
Регистрация: 22.02.2013
Сообщений: 5,847
Записей в блоге: 79
17.05.2020, 17:11
Цитата Сообщение от Argus19 Посмотреть сообщение
делал цвета формы и Picture Box = vbTransparent. Прозрачным, как ожидалось, ничто не стало. Почему, заголовок формы прозрачен, а остальное нет?
Посмотри к чему относится константа vbTransparent, ни разу ни цвет фона.
Для "стеклянного" эффекта необходимо использовать функции DWM:
0
 Аватар для Argus19
1427 / 444 / 78
Регистрация: 24.09.2017
Сообщений: 2,525
Записей в блоге: 22
17.05.2020, 17:21  [ТС]
Pro_grammer, спасибо. Ваш код делает прозрачным форму и всё, что находится на ней.
Я попробовал:
Visual Basic
1
SetTrans Picture1.hWnd, 120
визуально ничего не изменилось, по сравнению с обычными параметрами формы и Picture Box. Была надежда сделать на месте Picture Box "дырку", не затрагивая остальной формы.
0
Модератор
10048 / 3894 / 883
Регистрация: 22.02.2013
Сообщений: 5,847
Записей в блоге: 79
17.05.2020, 17:23
Цитата Сообщение от Argus19 Посмотреть сообщение
визуально ничего не изменилось, по сравнению с обычными параметрами формы и Picture Box. Была надежда сделать на месте Picture Box "дырку", не затрагивая остальной формы.
Чтобы так сделать нужно использовать LWA_COLORKEY.
0
 Аватар для Argus19
1427 / 444 / 78
Регистрация: 24.09.2017
Сообщений: 2,525
Записей в блоге: 22
17.05.2020, 17:40  [ТС]
Цитата Сообщение от The trick Посмотреть сообщение
нужно использовать LWA_COLORKEY
Так в вышеприведённом примере она используется.
0
Модератор
10048 / 3894 / 883
Регистрация: 22.02.2013
Сообщений: 5,847
Записей в блоге: 79
17.05.2020, 18:07
Цитата Сообщение от Argus19 Посмотреть сообщение
Так в вышеприведённом примере она используется.
Нет, там используется LWA_ALPHA.
Вложения
Тип файла: zip crKey.zip (1.4 Кб, 11 просмотров)
1
 Аватар для Pro_grammer
6807 / 2839 / 527
Регистрация: 24.04.2011
Сообщений: 5,308
Записей в блоге: 10
17.05.2020, 18:30
Цитата Сообщение от Argus19 Посмотреть сообщение
Picture Box "дырку", не затрагивая остальной формы.
Это ещё проще. Назначаете на Picture1.BackColor = &HFFFFF1 любой цвет, который заведомо не будет использоваться в другом месте, где не нужна дырка, он и будет COLORKEY:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hWnd As Long, ByVal nIndex As Long) As Long
 Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hWnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
 Private Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hWnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long
 Const LWA_COLORKEY = &H1
 Const LWA_ALPHA = &H2
 Const GWL_EXSTYLE = (-20)
 Const WS_EX_LAYERED = &H80000
 Private Sub Form_Load()
 Picture1.BackColor = &HFFFFF1
 Dim Ret As Long
 Ret = GetWindowLong(Me.hWnd, GWL_EXSTYLE)
 Ret = Ret Or WS_EX_LAYERED
 SetWindowLong Me.hWnd, GWL_EXSTYLE, Ret
 SetLayeredWindowAttributes Me.hWnd, &HFFFFF1, 0, LWA_COLORKEY
 End Sub
1
 Аватар для Argus19
1427 / 444 / 78
Регистрация: 24.09.2017
Сообщений: 2,525
Записей в блоге: 22
17.05.2020, 19:06  [ТС]
Цитата Сообщение от The trick Посмотреть сообщение
Нет, там используется LWA_ALPHA.
В строке №4, в строке №3
Visual Basic
1
Const LWA_COLORKEY = 1
Или вы имеете ввиду строку №33 -
Visual Basic
1
    SetLayeredWindowAttributes hWnd, RGB(255, 255, 0), Trans, LWA_ALPHA
?
Ваш пример - то, что надо!
0
Модератор
10048 / 3894 / 883
Регистрация: 22.02.2013
Сообщений: 5,847
Записей в блоге: 79
17.05.2020, 19:06
Цитата Сообщение от Argus19 Посмотреть сообщение
В строке №4, в строке №3
Эта константа не используется в коде, если обратить внимание.
0
 Аватар для Argus19
1427 / 444 / 78
Регистрация: 24.09.2017
Сообщений: 2,525
Записей в блоге: 22
17.05.2020, 19:18  [ТС]
Цитата Сообщение от Pro_grammer Посмотреть сообщение
Это ещё проще
Спасибо!

Добавлено через 1 минуту
Цитата Сообщение от The trick Посмотреть сообщение
если обратить внимание
Так я и написал про строку №33.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.05.2020, 19:18
Помогаю со студенческими работами здесь

Resize Picture Box - позиционирование текста
Здравствуйте. У меня следующая проблема. Вывожу на диаграмму текст в определенные координаты Picture Box (x=-0.091; y=0.179). Текст...

Цикл For для загрузки картинок в Picture Box
Кто-нибудь может объяснить, почему не работает следующий код? For i = 1 To 31 Step 1 Worksheets(i).Image2.Picture =...

Как задать диапазон Shapes. Range(Array("Text box 1", "Text box 2", "Text box 3", "Text box 4"."Text box 10").Select
Здравствуйте, все. Подскажите, пожалуйста, возможно ли в макросе VBA MS Word заменить область перечисляющихся значений в области Shapes....

Как запретить заход одного объекта (picture box) на другой picture box
Создаю платформер на Windows Forms, как запретить заход одного picture box'a на другой?

Picture box
Нужно создать программу. Суть программы: Небходимо передвинуть картинки чтобы получилось изображение и надпись &quot;портрет&quot;. Я...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru