Universal Windows Platform apps

From Wikipedia the free encyclopedia

Khan Academy, an example of a Universal Windows App
Left: A traditional desktop app without contents; it is showing 60 graphical widgets, and a thick border.
Right: Metro-style app; entirely composed of contents

Universal Windows Platform (UWP) apps[1] (formerly named Windows Store apps, Metro-style apps and Modern apps)[2] are applications that can be used across all compatible Microsoft Windows devices. They are primarily purchased and downloaded via the Microsoft Store, Microsoft's digital application storefront.[3]

Nomenclature

[edit]

Starting with Windows 10, Microsoft initially used the term "Windows app" to describe Universal Windows Platform (UWP) apps. These were applications that could be installed from the Microsoft Store, previously known as the Windows Store. Initially, these apps were called "Trusted Windows Store apps," and later they were referred to as "Trusted Microsoft Store apps." Traditional programs designed to run on desktop computers were referred to as "desktop apps."

With the release of the Windows 10, version 1903, there was a shift in the terminology. Microsoft began using the term "Apps" to refer to both UWP apps and desktop apps indiscriminately. This change aimed to unify the naming convention for all types of applications.

Note that UWP is primarily used in Microsoft's developer documentation to specifically refer to the platform itself. Microsoft also introduced the term "Windows Runtime app" retrospectively to describe the precursors of UWP apps, as there was previously no clear and unambiguous name for them.

In Windows 8.x

[edit]

UWP apps first became available under the name "Metro-style apps" in 2012 and were marketed with Windows 8.[2][4]

Look and feel

[edit]

In Windows 8.x, Metro-style apps do not run in a window. Instead, they either occupy the entire screen or are snapped to one side, in which case they occupy the entire height of the screen but only part of its width. They have no title bar, system menu, window borders or control buttons. Command interfaces like scroll bars are usually hidden on start. Menus are located in the "settings charm." Metro-style apps use the UI controls of Windows 8.x and typically follow Windows 8.x UI guidelines, such as horizontal scrolling and the inclusion of edge-UIs, like the app bar.[5]

In response to criticism from customers a title bar was added in Windows 8.1, but was hidden unless users move the mouse cursor to the top of the screen. However, the Hamburger button on the title bar gives access to the charms.[5]

Distribution and licensing

[edit]

For most users, the only point of entry for Metro-style apps is the Windows Store. Enterprises operating a Windows domain infrastructure may enter into a contract with Microsoft that allows them to sideload their line-of-business Metro-style apps, circumventing Windows Store. Also, major web browser vendors are selectively exempted from this rule, they are allowed to circumvent Microsoft guidelines and Windows Store and run a Metro-style version of themselves if the user chooses to make their product the default web browser.[6][7]

Windows RT requires all installed apps to be from the Windows Store, or be verified by Microsoft (most internal applications).

Multiple copies

[edit]

Before Windows 8, programs were identified by their static computer icons. The Windows taskbar was responsible for representing every app that had a window while running. Metro-style apps, however, are identified by their "tiles" that can show their icon and also other dynamic contents. In addition, in Windows 8 and Windows 8.1 RTM, they are not shown on the Windows taskbar when they run, but on a dedicated app switcher on the left side of the screen.[8] Windows 8.1 Update added taskbar icons for Metro-style apps.[9]

There is no set limit on how many copies of desktop apps can run simultaneously. For example, one user may run as many copies of programs such as Windows Notepad, Paint or Firefox as long as the system resources can support. (Some desktop apps, such as Windows Media Player, have extra code that prevents spawning more than one instance.) However, in Windows 8, only one copy of Metro-style apps may run at any given time. True multi-instancing of these apps were not available until Windows 10 version 1803 (released in May 2018).[10]

In Windows 10 and Windows 11

[edit]

Look and feel

[edit]

UWP apps are designed by individuals or software companies which leads to apps having their own look and feel. However, UWP apps built specifically for Windows 10 and 11 typically appear and function differently than ones on older versions, as they use new UI controls that look different from those of previous versions of Windows. The exception to this are apps that use custom UI, which is especially the case with video games. Apps designed for Windows 8.x look significantly different from those designed for Windows 10 and 11.[citation needed]

UWP apps can also look almost identical to traditional desktop apps, using the same legacy UI controls from Windows versions dating back to Windows 95. These are legacy desktop apps that are converted to the UWP apps and distributed using the APPX file format.[citation needed]

Multitasking

[edit]

In Windows 10, most UWP apps, even those designed for Windows 8.x, are run in floating windows, and users can use the Windows taskbar and Task View to switch between both UWP apps and desktop apps. Windows 10 also introduced "Tablet Mode". This mode is by default disabled on desktop computers and enabled on tablet computers, but desktop users can switch it on or off manually. When the Tablet Mode is off, apps may have resizable windows and visible title bars. When the Tablet Mode is enabled, resizable apps use the windowing system similar to that of Metro-style apps on Windows 8.x in that they are forced to either occupy the whole screen or be snapped to one side.[11][12][13]

UWP apps in Windows 10 can open in multiple windows. Microsoft Edge, Calculator, and Photos are examples of apps that allow this. Windows 10 v1803 (released in May 2018) added true multi-instancing capabilities, so that multiple independent copies of a UWP app can run.[10]

Licensing and distribution

[edit]

UWP apps can be downloaded from Windows Store or can be sideloaded. The sideloading requirements were reduced significantly from Windows 8.x to 10, but the app must still be signed by a trusted digital certificate that chains to a root certificate.[14]

Lifecycle

[edit]

Metro-style apps are suspended when they are closed; suspended apps are terminated automatically as needed by a Windows app manager. Dynamic tiles, background components and contracts (interfaces for interacting with other apps) may require an app to be activated before a user starts it.[15][16]

Invoking an arbitrary Metro-style app or UWP app from the command line was first introduced in the Insider build 16226 of Windows 10,[17] which was released on 21 June 2017.[18]

Development

[edit]

Windows Runtime

[edit]

Traditionally, Windows software is developed using the Windows API. Software has access to the Windows API with no arbitrary restrictions. Developers were free to choose their own programming language and development tools. Metro-style apps can only be developed using Windows Runtime (WinRT). (Note that not every app using WinRT is a Metro-style app.) A limited subset of WinRT is available for also conventional desktop apps.[19] Calling a forbidden API disqualifies the app from appearing on Windows Store.

Metro-style apps can only be developed using Microsoft's own development tools. According to Allen Bauer, Chief Scientist of Embarcadero Technologies, there are APIs that every computer program must call but Microsoft has forbidden them, except when the call comes from Microsoft's own Visual C++ runtime.[20][21][22]

Universal apps

[edit]

UWP apps developed to work on smartphones, personal computers, video game consoles and HoloLens. They were initially called universal apps because they derived their platform flexibility from the universal apps API, first introduced in Windows 8.1 and Windows Phone 8.1. Visual Studio 2013 with Update 2 could be used to develop these apps.[23][24] Windows 10 introduced the Universal Windows Platform (UWP) 10 API for developing universal apps. Apps that take advantage of this platform are developed with Visual Studio 2015 or later. Older Metro-style apps for Windows 8.1, Windows Phone 8.1 or for both (universal 8.1) need modifications to migrate to this platform.[25][26]

Universal apps no longer indicate having been written for a specific OS in their manifest; instead, they target one or more device families, e.g. desktop, mobile, console or Internet of Things (IoT). They react to the capabilities that become available to the device. A universal app may run on both a mobile phone and a tablet and provide a suitable experience. The universal app running on the mobile phone may start behaving the way it would on a tablet when the phone is connected to a monitor or a suitable docking station.[27]

UWP is an extension of Windows Runtime and has access to WinRT APIs, although whether UWP apps can take advantage of WinRT APIs depends on their programming language and its tooling.[28]

APPX

[edit]
APPX
Filename extension
.appx, .appxbundle
Developed byMicrosoft
Type of formatArchive
Container forInstallation information and an EXE or MSI file
Contained byZIP, OPC
Extended toMSIX
Open format?Yes

APPX is a file format used to distribute and install apps on Windows 8.x, 10, 11, Windows Phone 8.1, Windows 10 Mobile, Xbox One, Xbox Series X|S, Hololens, and Windows 10 IoT Core.[29] APPX was originally the only installation system allowed for UWP apps, replacing the XAP file format on Windows Phone 8.1, in an attempt to unify the distribution of apps for Windows Phone and Windows 8.[30] APPX files are only compatible with Windows Phone 8.1 and later versions, and with Windows 8 and later versions.[31]

The Windows Phone 8.x Marketplace allowed users to download APPX files to an SD Card and install them manually. In contrast, sideloading of UWP apps was prohibited on Windows 8.x, unless the user had a developers license or was in a business domain.[32][unreliable source?]

MSIX

[edit]
MSIX
Filename extension
.msix, .msixbundle
Developed byMicrosoft
Type of formatArchive
Container forInstallation information, an EXE file, DLL files, and/or other bundled content ("assets")
Contained byZIP, OPC
Extended fromApp-V, APPX, MSI
Open format?Yes

Windows 10 version 1709 and Windows Server 2019 LTSC introduced a new installation package format called MSIX, which is intended to be a replacement for both the APPX format and the Windows Installer (.msi) desktop application installation format.[33] MSIX is now the preferred way of distributing UWP apps.[34] An open source project called MSIX Core was started to provide MSIX support for Windows versions earlier than Windows 10 version 1709.[35]

Security

[edit]

Traditional Windows applications generally have the power to use and change their ecosystem however they want to. Windows user account rights, User Account Control and antivirus software attempt to keep this ability in check and notify the user when the app tries to use it, possibly for malicious purposes. UWP apps, however, are sandboxed and cannot permanently change a Windows ecosystem. They need permission to access hardware devices such as webcams, microphones or their file system which is restricted to user folders, such as My Documents. Microsoft further moderates these programs and may remove them from the Windows Store if they are discovered to have security or privacy issues.[36][37]

See also

[edit]

References

[edit]
  1. ^ Weinberger, Matt (March 17, 2016), Microsoft is trying to change Windows software forever — here's why it'll be a tough fight, retrieved June 27, 2016
  2. ^ a b Harrel, William (April 10, 2015), "Metro, Modern, Now Universal? Microsoft Can't Make Up Its Mind!", Digital Trends, retrieved June 27, 2016
  3. ^ Weinberger, Matt (March 4, 2016), "Microsoft's Windows app strategy comes under fire: 'The most aggressive move Microsoft has ever made'", Business Insider, retrieved June 27, 2016
  4. ^ Newman, Jared (March 26, 2015), "Microsoft's Metro apps rechristened with a new, sixth name: Windows apps", PCWorld, retrieved June 27, 2016
  5. ^ a b Leonhart, Woody (8 April 2014). "What's new in Windows 8.1 Update". InfoWorld. IDG.
  6. ^ Bott, Ed (15 January 2014). "Google's latest Chrome release tries to replace the Windows 8 desktop". ZDNet. CBS Interactive. Under Microsoft's rules, Metro-style browsers are able to sidestep requirements that apply to all other apps, including the mandate to be distributed through the Windows Store
  7. ^ Branscombe, Mary (27 March 2012). "Windows 8 browsers: the only Metro apps to get desktop power". TechRadar. Future Publishing. Retrieved 17 January 2014.
  8. ^ "Switch between open apps". Microsoft Surface manual. Microsoft. Retrieved 31 December 2013.
  9. ^ Fitzsimmons, Michelle (May 13, 2014). "Windows 8.1 Update 1: hands on with Microsoft's latest Windows update". TechRadar. Future plc. Retrieved May 19, 2014.
  10. ^ a b Whitechapel, Andrew (May 2018). "Universal Windows Platform - Closing UWP-Win32 Gaps". MSDN Magazine. Vol. 33, no. 5. Microsoft.
  11. ^ Seifert, Dan (29 July 2015). "The nine most important updates in Windows 10". The Verge. Vox Media.
  12. ^ Warren, Tom (28 July 2015). "Windows 10 review". The Verge. Vox Media.
  13. ^ Bott, Ed (28 July 2015). "Windows 10: A new beginning". ZDNet. CBS Interactive.
  14. ^ Sheehan, John; Zanjani, Peyman (30 March 2016). Project Centennial: Bringing Existing Desktop Applications to the Universal Windows Platform. Microsoft Build 2016 Conference (Video). San Francisco: Microsoft Corporation. 8:50 minutes in. Archived from the original on 29 January 2018. Retrieved 3 April 2016.
  15. ^ Joshi, Bipin (22 February 2013). "Understanding Windows Store App Lifecycle and State Management". Code Guru. QuinStreet.
  16. ^ Hale, David (7 March 2016). "Universal Windows Platform (UWP) app lifecycle". UWP documentation. Microsoft – via Microsoft Learn].
  17. ^ Whitechapel, Andrew (5 July 2017). "Command-Line Activation of Universal Windows Apps". Building Apps for Windows. Microsoft.
  18. ^ Sarkar, Dona (21 June 2017). "Announcing Windows 10 Insider Preview Build 16226 for PC". Windows Experience Blog. Microsoft.
  19. ^ "Windows Runtime 8.x APIs for desktop apps". Windows App Development. Microsoft. Retrieved 31 July 2015 – via Microsoft Learn.
  20. ^ Grange, Eric (23 August 2012). "Why no native WinRT support in Delphi XE3?". DelphiTools. Retrieved 13 January 2014.
  21. ^ Anderson, Tim (23 August 2012). "Third-party compilers locked out of Windows Runtime development". Tim Anderson's ITWriting. Retrieved 13 January 2014.
  22. ^ Bauer, Allen (22 August 2012). "HTML5 Builder". Embarcadero Developer Network. Embarcadero Technologies. Archived from the original on 14 June 2020. Retrieved 13 January 2014.
  23. ^ Gallo, Kevin (2 March 2015). "A first look at the Windows 10 universal app platform". Windows Developer Blog. Microsoft.
  24. ^ Appel, Rachel (September 2014). "Modern Apps : Build Universal Apps for the Windows Platform". MSDN Magazine. 29 (9). Microsoft – via Microsoft Learn.
  25. ^ "Migrate apps to the Universal Windows Platform (UWP)". Archived Visual Studio Documentations. Microsoft. Retrieved 31 July 2015 – via Microsoft Learn.
  26. ^ "Move from Windows Runtime 8.x to UWP". UWP documentation. Microsoft. Retrieved 31 July 2015 – via Microsoft Learn.
  27. ^ "What's a Universal Windows Platform (UWP) app?". UWP documentation. Microsoft. 20 April 2022. Adaptive controls and input – via Microsoft Learn.
  28. ^ "What's a Universal Windows Platform (UWP) app?". UWP documentation. Microsoft. 20 April 2022. How the Universal Windows Platform relates to Windows Runtime APIs – via Microsoft Learn.
  29. ^ "App packages and deployment (Windows Runtime apps)". Windows 8 development. Microsoft. 6 October 2015. Retrieved 8 March 2016 – via Microsoft Learn.
  30. ^ Warren, Tom (11 February 2014). "Windows Phone 8.1 includes universal apps and lots of feature updates". The Verge. Vox Media.
  31. ^ How to Install APPX File on Windows Phone 8.1 Archived April 25, 2015, at the Wayback Machine
  32. ^ "How To Sideload Modern Apps on Windows 8". How-To Geek. 23 November 2012.
  33. ^ "What is MSIX?". 11 June 2022. Retrieved 3 September 2024.
  34. ^ "Get started: Publish your first app in the Microsoft Store". 23 July 2024. Retrieved 3 September 2024.
  35. ^ "MSIX Core". 6 October 2022. Retrieved 3 September 2024.
  36. ^ Ziegler, Chris (17 May 2012). "Microsoft talks Windows Store features, Metro app sandboxing for Windows 8 developers". The Verge. Vox Media. Retrieved 12 January 2013.
  37. ^ Rosoff, Matt (9 February 2012). "Here's Everything You Wanted To Know About Microsoft's Upcoming iPad Killers". Business Insider. Archived from the original on 22 January 2013. Retrieved 12 January 2013.