Advanced .NET MAUI Topic: Visual State

With the release of my newest book, .NET MAUI For C# Developers, I’m pleased to present occasional posts on advanced topics. If you are just starting out, however, you may want to take a look at my previous 15 part series in which I learn .NET MAUI or my second series that uses the app (Forget Me Not) that we’ll be using here. Finally, you can find my presentations on .NET MAUI and advanced .NET MAUI on YouTube, here.

Managing Visual State

Every VisualElement has a Visual State. For example, does the VisualElement have focus? Is it selected? Xaml allows you to change the presentation of that VisualElement (e.g., a button) based on that state.

The object that sets visual properties on a VisualElement based on its state is the Visual State Manager. The Visual State Manager selects from among a set of VisualStates and displays the view according to styles that you create.

Defining the common visual states

.NET MAUI defines a set of common visual states:

  • Normal
  • Disabled
  • Has focus
  • Is selected
  • Mouse over (for Windows and MacOs)

.NET MAUI also allows you to define your own visual states.

Button VisualState example

When you first come to the Login page in Forget Me Not, the Submit button is disabled. Once you fill in the two fields of Your Email and Password, the button should turn light green. If you tab to the button it should signify that it has the focus by turning fully green. You can do all this declarative with Visual States.

Visual State and Styles

You can set the visual state on an individual button, or, as we will do here, you can put the visual state XAML into a style and apply it to all the buttons. Here is the complete Style for buttons:

<Style x:Key="LoginButton" TargetType="Button"> 

    <Setter Property="Margin" Value="0,20,0,0" />

    <Setter Property="TextColor" Value="Black" />

    <Setter Property="WidthRequest" Value="125" />

    <Setter Property="VisualStateManager.VisualStateGroups"> 

        <VisualStateGroupList> 

            <VisualStateGroup x:Name="CommonStates"> 

                <VisualState x:Name="Normal"> 

                    <VisualState.Setters> 

                        <Setter Property="BackgroundColor" Value="LightGreen" />

                    </VisualState.Setters>

                </VisualState>

                <VisualState x:Name="Focused">

                    <VisualState.Setters>

                        <Setter Property="BackgroundColor" Value="Green" />

                    </VisualState.Setters>

                </VisualState>

                <VisualState x:Name="Disabled">

                    <VisualState.Setters>

                        <Setter Property="BackgroundColor" Value="Gray" />

                    </VisualState.Setters>

                </VisualState>

            </VisualStateGroup>

        </VisualStateGroupList>

    </Setter>

</Style>

We start by declaring a normal Style, in this case implicit for every button. You may have one or more groups of visual states (we have one). The first group (and in this case the only one) is the CommonStates

We declare each VisualState in turn (here we’re starting with Normal). For each state, we can declare a set of Setters. Our first (and in this case only) Setter sets the BackgroundColor property

We then go on to set the Setters for all the other states. Notice that we did not set the Setter for PointerOver, which means that, on Windows and macOS, if you hover the mouse over the button there will be no change.

.NET MAUI defines specialized visual states for controls. For example, Button adds the Pressed state while CheckBox adds the IsChecked state and CollectionViews adds Selected.

The .NET MAUI community toolkit provides further help for managing the appearance and behavior of your app with a large collection of Behaviors.

About Jesse Liberty

Jesse Liberty has three decades of experience writing and delivering software projects and is the author of 2 dozen books and a couple dozen online courses. His latest book, Building APIs with .NET will be released early in 2025. Liberty is a Senior SW Engineer for CNH and he was a Senior Technical Evangelist for Microsoft, a Distinguished Software Engineer for AT&T, a VP for Information Services for Citibank and a Software Architect for PBS. He is a Microsoft MVP.
This entry was posted in .NET MAUI and tagged , , . Bookmark the permalink.

42 Responses to Advanced .NET MAUI Topic: Visual State

  1. Wileyfew says:

    Here are presented special bonus codes for One X Bet.
    These promocodes give access to acquire supplementary advantages when playing on the site.
    All existing discount vouchers are regularly updated to confirm their effectiveness.
    When using these promotions one can boost your possibilities on the gaming site.
    https://norelem-academy.com/wp-content/pgs/mylynyanka_ukrasit_alypiyskuyu_gorku.html
    Furthermore, full explanations on how to implement promocodes are included for maximum efficiency.
    Consider that selected deals may have expiration dates, so review terms before using.

  2. Wileyfew says:

    This resource are presented useful promo codes for One X Bet.
    These special offers give access to receive extra incentives when betting on the site.
    Available discount vouchers are always up-to-date to maintain their usability.
    By applying these offers one can raise your gaming experience on the betting platform.
    https://schoolnewsportal.com/wp-content/pgs/neskolyko_sposobov_poluchity_na_svadybu_ghelannye_podarki.html
    In addition, full explanations on how to apply promo deals are available for ease of use.
    Remember that specific offers may have particular conditions, so look into conditions before activating.

  3. StevenVon says:

    In this place you can locate limited promo codes for the well-known gambling site.
    The range of special promotions is persistently enhanced to provide that you always have opportunity to use the newest deals.
    By applying these discounts, you can save a lot on your betting actions and boost your opportunities of winning.
    All promo codes are carefully checked for accuracy and effectiveness before showing up.
    https://juvalife.com/pag/kak_nakormity_rebenka.html
    Furthermore, we provide comprehensive guidelines on how to apply each discount offer to optimize your bonuses.
    Bear in mind that some deals may have definite prerequisites or set deadlines, so it’s critical to inspect diligently all the particulars before activating them.

  4. On this site relevant knowledge about steps to becoming a digital intruder.
    Facts are conveyed in a clear and concise manner.
    You may acquire various techniques for penetrating networks.
    Additionally, there are actual illustrations that exhibit how to utilize these skills.
    how to become a hacker
    Full details is often renewed to match the up-to-date progress in information security.
    Particular focus is paid to real-world use of the mastered abilities.
    Note that every procedure should be used legally and for educational purposes only.

  5. Looking for someone to take on a rare hazardous assignment?
    This platform focuses on connecting customers with contractors who are willing to tackle high-stakes jobs.
    Whether you’re handling urgent repairs, unsafe cleanups, or complex installations, you’ve come to the perfect place.
    Every listed professional is vetted and qualified to guarantee your safety.
    hire an assassin
    This service provide transparent pricing, comprehensive profiles, and safe payment methods.
    No matter how difficult the scenario, our network has the expertise to get it done.
    Begin your search today and locate the ideal candidate for your needs.

  6. 480656 74236Spot up for this write-up, I seriously believe this internet site needs a lot much more consideration. Ill apt to be once more to learn additional, appreciate your that information. 53397

  7. 色情网站 says:

    访问者请注意,这是一个成人网站。
    进入前请确认您已年满成年年龄,并同意接受相关条款。
    本网站包含成人向资源,请自行判断是否适合进入。 色情网站
    若您未满18岁,请立即退出页面。
    我们致力于提供优质可靠的网络体验。

  8. winspark says:

    791744 507757Id need to verify with you here. Which isnt one thing I often do! I get pleasure from reading a put up that will make individuals think. Furthermore, thanks for permitting me to comment! 668497

  9. Antonhiz says:

    Emotional withdrawal from intimacy can reverse with medical support like https://plaqcmd.com/# hydroxychloroquine for sale. Real care that fits both your needs and your budget.

  10. pg168 says:

    649384 607621brilliantly insightful post. If only it was as straightforward to implement some of the solutions as it was to read and nod my head at each of your points 321239

  11. play aviator says:

    On this platform, you can access lots of slot machines from famous studios.
    Visitors can experience classic slots as well as feature-packed games with stunning graphics and exciting features.
    Whether you’re a beginner or a casino enthusiast, there’s always a slot to match your mood.
    money casino
    Each title are ready to play round the clock and designed for laptops and smartphones alike.
    No download is required, so you can start playing instantly.
    The interface is user-friendly, making it quick to find your favorite slot.
    Join the fun, and discover the excitement of spinning reels!

  12. play casino says:

    Here, you can access a wide selection of slot machines from top providers.
    Visitors can enjoy traditional machines as well as new-generation slots with stunning graphics and interactive gameplay.
    Even if you’re new or a casino enthusiast, there’s a game that fits your style.
    money casino
    Each title are ready to play anytime and optimized for laptops and tablets alike.
    All games run in your browser, so you can jump into the action right away.
    The interface is easy to use, making it convenient to explore new games.
    Sign up today, and enjoy the world of online slots!

  13. MichaelCoind says:

    На данном ресурсе представлены последние информацию о событиях в стране и за рубежом. Информация поступает ежеминутно, что позволяет быть в курсе об актуальной повестке. Особое внимание уделяется различным аспектам жизни общества. Команда специалистов собрали информацию, которые будут полезны тем, кто интересуется новостями. Также доступны аналитические статьи, помогающие глубже понять современный контекст.
    http://fantasy.clanweb.eu/viewtopic.php?f=6&t=142834

  14. MichaelCoind says:

    На данном ресурсе представлены последние информацию о событиях в стране и за рубежом. Информация поступает в режиме реального времени, что позволяет быть в курсе об актуальной повестке. Особое внимание уделяется ключевым темам дня. Профессиональные журналисты собрали информацию, которые будут важны широкому кругу читателей. В отдельных категориях собраны аналитические статьи, помогающие глубже понять текущие события.
    https://nasuang.go.th/forum/suggestion-box/929681-n-ih-s-i-h-vi-ci-n-v-s-i

  15. Briansclub says:

    425840 229503Perfectly composed content , thankyou for entropy. 185318

  16. Questa pagina rende possibile l’ingaggio di persone per compiti delicati.
    Gli utenti possono ingaggiare esperti affidabili per operazioni isolate.
    Gli operatori proposti sono selezionati con attenzione.
    ordina omicidio
    Attraverso il portale è possibile leggere recensioni prima della selezione.
    La sicurezza rimane un nostro impegno.
    Contattateci oggi stesso per ottenere aiuto specializzato!

  17. This platform lets you get in touch with professionals for occasional high-risk missions.
    Clients may securely schedule help for unique needs.
    Each professional are qualified in handling critical jobs.
    hitman-assassin-killer.com
    This service guarantees discreet arrangements between requesters and freelancers.
    If you require urgent assistance, this platform is the perfect place.
    Submit a task and match with a professional instantly!

  18. This website offers you the chance to get in touch with workers for short-term hazardous projects.
    Users can efficiently arrange support for specialized operations.
    Each professional are experienced in managing intense tasks.
    assassin for hire
    The website provides discreet arrangements between employers and contractors.
    Whether you need a quick solution, our service is the perfect place.
    Submit a task and match with an expert now!

  19. Il nostro servizio rende possibile il reclutamento di operatori per compiti delicati.
    Gli utenti possono ingaggiare professionisti specializzati per operazioni isolate.
    Le persone disponibili sono selezionati con cura.
    ordina omicidio
    Attraverso il portale è possibile consultare disponibilità prima di procedere.
    La qualità rimane un nostro impegno.
    Iniziate la ricerca oggi stesso per portare a termine il vostro progetto!

  20. 888vipbet says:

    735278 636745Hi, Neat post. Theres a difficulty together with your web site in internet explorer, would test this IE nonetheless is the market leader and a big portion of people will miss your fantastic writing because of this difficulty. 465525

  21. Оформление страховки для заграничной поездки — это необходимая мера для спокойствия отдыхающего.
    Сертификат включает расходы на лечение в случае травмы за границей.
    Кроме того, страховка может включать покрытие расходов на транспортировку.
    страховка осаго
    Многие страны требуют предъявление страховки для получения визы.
    Если нет страховки госпитализация могут быть финансово обременительными.
    Приобретение документа заранее

  22. casino games says:

    This website, you can discover a wide selection of slot machines from famous studios.
    Users can experience traditional machines as well as new-generation slots with stunning graphics and interactive gameplay.
    Whether you’re a beginner or a casino enthusiast, there’s always a slot to match your mood.
    money casino
    Each title are available anytime and designed for PCs and mobile devices alike.
    All games run in your browser, so you can start playing instantly.
    Platform layout is intuitive, making it simple to explore new games.
    Join the fun, and enjoy the thrill of casino games!

  23. This section features multifunctional timepieces crafted by reputable makers.
    Browse through sleek CD units with AM/FM radio and dual wake options.
    These devices include aux-in ports, USB charging, and battery backup.
    Available products ranges from budget-friendly options to elite choices.
    alarm cd player
    All clocks boast sleep timers, auto-off timers, and LED screens.
    Shop the collection via direct eBay and no extra cost.
    Select the perfect clock-radio-CD setup for kitchen everyday enjoyment.

  24. DavidTwelt says:

    This service provides adventure rides on Crete.
    You can quickly rent a machine for travel.
    In case you’re looking to explore coastal trails, a buggy is the fun way to do it.
    https://www.tumblr.com/sneakerizer/781689118337990656/alligator-buggy-quad-safari-redefining-off-road
    Our rides are well-maintained and can be rented for full-day schedules.
    On this platform is user-friendly and comes with no hidden fees.
    Begin the adventure and feel Crete on your own terms.

  25. pg168 says:

    561630 845251I like your writing style truly loving this web site . 553656

  26. pg168 says:

    485790 745242Yeah bookmaking this wasnt a risky decision outstanding post! . 962869

  27. 922167 68599I gotta favorite this internet web site it seems handy . 315015

  28. Jamescrumn says:

    Our e-pharmacy offers a broad selection of pharmaceuticals at affordable prices.
    You can find all types of remedies for all health requirements.
    We work hard to offer trusted brands while saving you money.
    Speedy and secure shipping provides that your order gets to you quickly.
    Enjoy the ease of getting your meds with us.
    generic vs brand name drugs

  29. 36042 840672for but an additional excellent informative post, Im a loyal reader to this weblog and I cant stress enough how considerably valuable information Ive learned from reading your content. I truly appreciate all of the hard work you put into this great blog. 954407

  30. 197908 518955Yeah bookmaking this wasnt a speculative decision outstanding post! . 320520

  31. MichaelVilla says:

    Were you aware that 1 in 3 people taking prescriptions make dangerous pharmaceutical mishaps because of lack of knowledge?

    Your wellbeing is your most valuable asset. Every medication decision you make significantly affects your quality of life. Staying educated about your prescriptions should be mandatory for disease prevention.
    Your health isn’t just about following prescriptions. All pharmaceutical products changes your physiology in potentially dangerous ways.

    Never ignore these essential facts:
    1. Combining medications can cause fatal reactions
    2. Even common allergy medicines have potent side effects
    3. Self-adjusting treatment undermines therapy

    For your safety, always:
    ✓ Check compatibility with professional help
    ✓ Study labels completely prior to using new prescriptions
    ✓ Speak with specialists about proper usage

    ___________________________________
    For professional medication guidance, visit:
    https://community.alteryx.com/t5/user/viewprofilepage/user-id/576197

  32. slot casino says:

    Here, you can discover lots of online slots from leading developers.
    Users can experience retro-style games as well as new-generation slots with high-quality visuals and bonus rounds.
    Even if you’re new or an experienced player, there’s a game that fits your style.
    casino games
    The games are ready to play round the clock and compatible with desktop computers and tablets alike.
    All games run in your browser, so you can get started without hassle.
    The interface is user-friendly, making it convenient to find your favorite slot.
    Join the fun, and enjoy the thrill of casino games!

  33. rich89bet says:

    185127 221236Wow, suprisingly I never knew this. Maintain up with great posts. 524937

  34. 920023 854708you got a quite exceptional website, Sword lily I discovered it through yahoo. 762565

  35. 317333 660231Really interesting topic , appreciate it for putting up. 742597

  36. 632217 846905Howdy! I just want to give an enormous thumbs up for the excellent info you might have here on this post. I will likely be coming back to your weblog for a lot more soon. 65846

  37. mijn hor says:

    420274 10021I genuinely prize your function , Excellent post. 596143

  38. slot casino says:

    Here, you can access a wide selection of casino slots from leading developers.
    Users can enjoy retro-style games as well as modern video slots with stunning graphics and interactive gameplay.
    Whether you’re a beginner or a casino enthusiast, there’s a game that fits your style.
    casino games
    The games are ready to play round the clock and designed for PCs and smartphones alike.
    No download is required, so you can get started without hassle.
    Site navigation is intuitive, making it simple to find your favorite slot.
    Register now, and discover the thrill of casino games!

  39. xmfhQ7 says:

    644565 519898Hi, in case you want to get higher rankings, you must look at the plugin I left in my link, it will support. 550553

  40. I don’t think the title of your article matches the content lol. Just kidding, mainly because I had some doubts after reading the article.

Leave a Reply to play aviator Cancel reply

Your email address will not be published. Required fields are marked *