-
Data: 2011-08-27 18:27:09
Temat: Paradoksy [Win]API Microsoftu
Od: "Wojciech \"Spook\" Sura" <spook"mad@hatter"op.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Hej!
Nadziałem się dziś na dziwne ograniczenie w .NET Windows Forms, a ściślej
- w pionowym pasku przewijania. Otóż VScrollBar ma własność Maximum, która
wraz z Minimum pozwala na ograniczenie zakresu wartości osiąganych przez
pasek przewijania. I wszystko byłoby w porządku gdyby nie dwa fakty:
a) Użytkownik nie jest w stanie osiągnąć wartości Maximum, tylko Maximum +
1 - LargeChange, gdzie LargeChange to własność określająca, o ile
przesunie się suwak po kliknięciu obszaru przewijania (lub wciśnięciu
PageUp lub PageDown).
b) Wartości od (Maximum + 1 - LargeChange) do Maximum są wizualizowane
przez suwak ustawiony na maksymalnej pozycji - czyli użytkownik nie
zobaczy różnicy pomiędzy żadnym z tych ustawień.
Przyczyna takiego stanu rzeczy? Nieznana.
Kiedyś potrzebowałem narysować przy pomocy GDI/GDI+ prostokąt z
zaokrąglonymi narożnikami, wypełniony gradientem. W tym celu użyłem metody
CreateRoundRectRgn, tworzącej region o wspomnianym kształcie.
Każdy, kto bawił się trochę w WinAPI wie doskonale, że jeśli gdziekolwiek
podaje się wymiary prostokąta opisującego cokolwiek, trzeba zawsze
zwiększyć jego wymiary o jednostkę w poziomie i pionie, ponieważ WinAPI
utnie ostatnią prawą kolumnę i ostatni dolny wiersz. W ten sposób ze
współrzędnych (0, 0, 10, 10) zostanie utworzony prostokąt, którego prawy
dolny narożnik ma współrzędne (9, 9).
Microsoft jest bardzo konsekwentny w takiej a nie innej interpretacji
prostokąta i w sumie ma to trochę sensu - można na przykład definiować
prostokąt w nieco prostszy sposób: (x, y, x + width, y + height) zamiast
(x, y, x + width - 1, y + height - 1). Ponadto istnieje możliwość
utworzenia pustego regionu poprzez podanie równych współrzędnych (np. 0,
0, 0, 0).
Jednak okazuje się, że w przypadku (chyba jedynym) CreateRoundRectRgn
Microsoft się wyłamał i zamiast zjadać jedną kolumnę i jeden wiersz, zjada
dwa. Więc aby wygenerować region o współrzędnych (0, 0, 9, 9), należy
funkcji podać współrzędne (0, 0, 11, 11).
Przyczyna takiego stanu rzeczy? Nieznana.
Czy nadzialiście się kiedyś na takie dziwne, niewytłumaczalne ograniczenia
w różnych API? Czasami można stracić kilka dni na poszukiwaniu błędu,
którego w kodzie nie ma...
Pozdrawiam -- Spook.
--
! ._______. Warning: Lucida Console sig! //) !
! || spk || www.spook.freshsite.pl / _ """*!
! ||_____|| spook at op.pl / ' | ""!
! | ___ | tlen: spoko_ws gg:1290136 /. __/"\ '!
! |_|[]_|_| May the SOURCE be with you! \/) \ !
Następne wpisy z tego wątku
- 28.08.11 06:06 m...@t...pl
- 28.08.11 11:34 Marek
- 28.08.11 18:01 Wojciech \"Spook\" Sura
- 28.08.11 18:04 Wojciech \"Spook\" Sura
- 28.08.11 18:26 Wojciech \"Spook\" Sura
- 29.08.11 06:11 Paweł Kierski
- 29.08.11 06:26 m...@t...pl
- 31.08.11 08:28 Marek
Najnowsze wątki z tej grupy
- "Wuj dobra rada" z KDAB rozważa: Choosing the Right Programming Language for Your Embedded Linux Device
- Nowa ustawa o ochronie praw autorskich - opis problemu i szkic ustawy
- Alg. kompresji LZW
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
Najnowsze wątki
- 2025-04-05 Dziwny wymiar wyroku
- 2025-04-05 Prunt z dachu
- 2025-04-05 Taśma LED
- 2025-04-05 Kraków => MS Dynamics 365BC/NAV Developer <=
- 2025-04-05 Warszawa => Strategic Account Manager <=
- 2025-04-05 co w Anglii dziś w Polsce za 30 lat
- 2025-04-05 Wrocław => SOC Tech Lead <=
- 2025-04-05 Gdynia => Przedstawiciel handlowy / KAM (branża TSL) <=
- 2025-04-05 Wyrok dożywocia dla Polki
- 2025-04-04 Prezydium Sejmu Tuskiego orzekło: Poseł KO mecenas Roman Giertych NIE jest mordercą (w żadnym sensie tego słowa?)
- 2025-04-04 Reset komóry
- 2025-04-04 Lublin => JavaScript / Node / Fullstack Developer <=
- 2025-04-04 Zielonka => Key Account Manager IT <=
- 2025-04-04 Warszawa => Ekspert IT (obszar systemów sieciowych) <=
- 2025-04-04 Warszawa => Mid/Senior IT Recruiter <=