Uso del SDK de MSIX para distribuir un paquete MSIX en plataformas que no son de Windows 10

El SDK de MSIX ofrece a los desarrolladores una manera universal de distribuir el contenido del paquete a los dispositivos cliente independientemente de la plataforma del sistema operativo en el dispositivo cliente. Esto permite a los desarrolladores empaquetar el contenido de la aplicación una vez en lugar de tener que empaquetar para cada plataforma.

Para aprovechar el SDK de MSIX y la capacidad de distribuir el contenido del paquete a varias plataformas, proporcionamos una manera de especificar las plataformas de destino en las que desea que los paquetes se extraigan. Esto significa que puede asegurarse de que el contenido del paquete se extrae del paquete solo como desee.

En la tabla siguiente se muestran las familias de dispositivos de destino que se van a declarar en el manifiesto.

Plataforma Familia Familia de dispositivos de destino Notas
Windows 10 Teléfono





















Platform.All























Windows.Universal Windows.Mobile Dispositivos móviles
Escritorio Windows.Desktop PC
Xbox Windows.Xbox Consola Xbox
Surface Hub Windows.Team Dispositivos Win 10 de pantalla grande
HoloLens Windows.Holographic Casco VR/AR
IoT Windows.IoT Dispositivos IoT
iOS Teléfono Apple.Ios.All Apple.Ios.Phone iPhone, Touch
Tableta Apple.Ios.Tablet iPad mini, iPad, iPad Pro
TV Apple.Ios.TV Apple TV
Watch Apple.Ios.Watch iWatch
MacOS Escritorio Apple.MacOS.All MacBook Pro, MacBook Air, Mac Mini, iMac
Android Teléfono Google.Android.All Google.Android.Phone Dispositivos móviles que tienen como destino cualquier tipo de Android
Tableta Google.Android.Tablet Tabletas Android
Escritorio Google.Android.Desktop Chromebooks
TV Google.Android.TV Dispositivos Android de pantalla grande
Watch Google.Android.Watch Dispositivos de engranajes de Google
Windows 7 Windows7.Desktop Dispositivos con Windows 7
8 Windows8.Desktop Dispositivos con Windows 8/8.1
Web Microsoft Web.All Web.Edge.All Aplicaciones de motor web edge
Android Web.Blink.All Aplicaciones de motor web blink
Chrome Web.Chromium.All Aplicaciones de motor web chrome
iOS Web.Webkit.All Aplicaciones del motor web Webkit
MacOS Web.Safari.All Aplicaciones del motor web Safari
Linux Any/All Linux.All Todas las distribuciones de Linux

En el archivo de manifiesto del paquete de la aplicación, deberá incluir la familia de dispositivos de destino adecuada si desea que el contenido del paquete solo se extraiga en plataformas y dispositivos específicos. Si desea que el paquete sea compatible con todas las plataformas y tipos de dispositivos, elija Platform.All como familia de dispositivos de destino. Del mismo modo, si desea que el paquete solo se admita en aplicaciones web, elija Web.All.

Archivo de manifiesto de ejemplo (AppxManifest.xml)

<?xml version="1.0" encoding="utf-8"?>
<Package xmlns="http://schemas.microsoft.com/appx/manifest/foundation/windows10"
         xmlns:mp="http://schemas.microsoft.com/appx/2014/phone/manifest"
         xmlns:uap="http://schemas.microsoft.com/appx/manifest/uap/windows10"
         xmlns:uap3="http://schemas.microsoft.com/appx/manifest/uap/windows10/3"
         IgnorableNamespaces="mp uap uap3">

  <Identity Name="BestAppExtension"
            Publisher="CN=awesomepublisher"
            Version="1.0.0.0" />

  <mp:PhoneIdentity PhoneProductId="56a6ecda-c215-4864-b097-447edd1f49fe" PhonePublisherId="00000000-0000-0000-0000-000000000000"/>

  <Properties>
    <DisplayName>Best App Extension</DisplayName>
    <PublisherDisplayName>Awesome Publisher</PublisherDisplayName>
    <Description>This is an extension package to my app</Description>
    <Logo>Assets\StoreLogo.png</Logo>
  </Properties>

  <Resources>
    <Resource Language="x-generate"/>
  </Resources>

  <Dependencies>
    <TargetDeviceFamily Name="Platform.All" MinVersion="0.0.0.0" MaxVersionTested="0.0.0.0"/>
  </Dependencies>

  <Applications>
    <Application Id="App">
      <uap:VisualElements
          DisplayName="Best App Extension"
          Description="This is the best app extension"
          BackgroundColor="white"
          Square150x150Logo="images\squareTile-sdk.png"
          Square44x44Logo="images\smallTile-sdk.png"
          AppListEntry="none">
      </uap:VisualElements>

      <Extensions>
        <uap3:Extension Category="Windows.appExtension">
          <uap3:AppExtension Name="add-in-contract" Id="add-in" PublicFolder="Public" DisplayName="Sample Add-in" Description="This is a sample add-in">
            <uap3:Properties>
               <!--Free form space-->
            </uap3:Properties>
          </uap3:AppExtension>
        </uap3:Extension>
      </Extensions>

    </Application>
  </Applications>
</Package>

Versión de la plataforma

En el archivo de manifiesto de ejemplo anterior, junto con el nombre de la plataforma, también hay parámetros para especificar MinVersion y MaxVersionTested Estos parámetros se usan en plataformas de Windows 10. En Windows 10, el paquete solo se implementará en versiones del sistema operativo Windows 10 superiores a MinVersion. En otras plataformas que no son de Windows 10, los parámetros MinVersion y MaxVersionTested no se usan para realizar la declaración de si se va a extraer el contenido del paquete.

Si quiere usar el paquete para todas las plataformas (Windows 10 y no Windows 10), le recomendamos que use los parámetros MinVersion y MaxVersionTested para especificar las versiones del sistema operativo Windows 10 donde quiera que funcione la aplicación. Por lo tanto, la sección Dependencias del manifiesto tendría este aspecto:

  <Dependencies>
    <TargetDeviceFamily Name="Platform.All" MinVersion="0.0.0.0" MaxVersionTested="0.0.0.0"/>
    <TargetDeviceFamily Name="Windows.Universal" MinVersion="10.0.14393.0" MaxVersionTested="10.0.16294.0"/>
  </Dependencies>

MinVersion y MaxVersionTested son campos obligatorios en el manifiesto y deben cumplir la notación cuádruple(#.#.#.#). Si solo usa el SDK de empaquetado de MSIX para plataformas que no sean Windows 10, puede usar simplemente '0.0.0.0' como MinVersion y MaxVersionTested como versiones.

Cómo usar eficazmente el mismo paquete en todas las plataformas (Windows 10 y no Windows 10)

Para aprovechar al máximo el SDK de empaquetado de MSIX, tendrás que compilar el paquete de una manera que se implementará como un paquete de aplicación en Windows 10 y al mismo tiempo compatible con otras plataformas. En Windows 10, puede crear el paquete como una Extensión de aplicación. Para obtener más información sobre las extensiones de aplicación y cómo pueden ayudar a que la aplicación sea extensible, consulte la entrada de blog Introducción a las extensiones de aplicación.

En el ejemplo de archivo de manifiesto mostrado anteriormente en este artículo, observará un elemento Properties dentro del elemento AppExtension. No se realiza ninguna validación en esta sección del archivo de manifiesto. Esto permite a los desarrolladores especificar los metadatos necesarios entre la extensión y la aplicación host/cliente.