Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
As propriedades do MSBuild controlam o comportamento dos alvos.
Eles são especificados no arquivo de projeto, por exemplo , MyApp.csproj, em um PropertyGroup do MSBuild.
Observação
No .NET para Android, tecnicamente não há distinção entre um aplicativo e um projeto de associações, portanto, as propriedades funcionarão em ambos. Na prática, é altamente recomendável criar projetos separados de aplicativos e associações. As propriedades usadas principalmente em projetos de bindings estão documentadas no guia de referência de propriedades do MSBuild para projetos de bindings.
AdbTarget
A $(AdbTarget) propriedade especifica o dispositivo de destino Android no qual o pacote Android pode ser instalado ou removido.
O valor desta propriedade é o mesmo que a opção adb Dispositivo Alvo.
AfterGenerateAndroidManifest
Os destinos do MSBuild listados nessa propriedade serão executados diretamente após o destino interno _GenerateJavaStubs, onde o arquivo AndroidManifest.xml é gerado no $(IntermediateOutputPath). Se você quiser fazer alguma modificação no arquivo gerado AndroidManifest.xml , poderá fazer isso usando este ponto de extensão.
AndroidAapt2CompileExtraArgs
Especifica as opções de linha de comando a serem passadas para o comando aapt2 compile ao processar ativos e recursos do Android.
AndroidAapt2LinkExtraArgs
Especifica as opções de linha de comando a serem passadas para o comando aapt2 link ao processar ativos e recursos do Android.
AndroidAddKeepAlives
Uma propriedade booleana que controla se o vinculador inserirá GC.KeepAlive() invocações em projetos de vinculação para evitar a coleta prematura de objetos.
O valor padrão é True para builds de configuração de release.
AndroidAotAdditionalArguments
Uma propriedade de cadeia de caracteres que permite passar opções para o compilador Mono durante a Aot tarefa para projetos que têm $(AndroidEnableProfiledAot) ou $(AotAssemblies) definidos como true.
O valor da cadeia de caracteres da propriedade é adicionado ao arquivo de resposta ao chamar o compilador cruzado Mono.
Em geral, essa propriedade deve ser deixada em branco, mas em determinados cenários especiais ela pode fornecer flexibilidade útil.
A $(AndroidAotAdditionalArguments) propriedade é diferente da propriedade relacionada $(AndroidExtraAotOptions) ; $(AndroidAotAdditionalArguments) passa opções separadas por espaço autônomas completas, como --verbose ou --debug para o compilador AOT, enquanto $(AndroidExtraAotOptions) contém argumentos separados por vírgula --aot que fazem parte da opção do compilador AOT.
CaminhoDePerfilPersonalizadoAndroidAot
O arquivo que aprofutil deve ser criado para armazenar dados do criador de perfil.
Perfis AndroidAot
Uma propriedade de string que permite ao desenvolvedor adicionar perfis AOT a partir da linha de comando. É uma lista separada por ponto e vírgula ou vírgula de caminhos absolutos.
AndroidAotProfilerPort
A porta à qual aprofutil deve se conectar ao obter dados de perfil.
AndroidAotEnableLazyLoad
Habilite o carregamento lento (atrasado) de assemblies AOT-d, em vez de pré-carregá-los na inicialização. O valor padrão é True para compilações de lançamento com qualquer forma de AOT habilitada.
Introduzido no .NET 6.
AndroidApkDigestAlgoritmo
Um valor de cadeia de caracteres que especifica o algoritmo de resumo a ser usado com jarsigner -digestalg.
O valor padrão é SHA-256.
AndroidApkSignerAdditionalArguments
Uma propriedade de cadeia de caracteres que permite que o desenvolvedor forneça argumentos para a apksigner ferramenta.
AndroidApkSigningAlgorithm
Valor de cadeia de caracteres que especifica o algoritmo de assinatura a ser usado com jarsigner -sigalg.
O valor padrão é SHA256withRSA.
Aplicativo Android
Um valor booleano que indica se o projeto é para um aplicativo Android (True) ou para um projeto de biblioteca Android (False ou não está presente).
Apenas um projeto com <AndroidApplication>True</AndroidApplication> pode estar presente em um pacote Android. (Infelizmente, esse requisito não é verificado, o que pode resultar em erros sutis e bizarros em relação aos recursos do Android.)
AndroidApplicationJavaClass
O nome completo da classe Java a ser usado no lugar de android.app.Application quando uma classe herda de Android.App.Application.
A $(AndroidApplicationJavaClass) propriedade geralmente é definida por outras propriedades, como a $(AndroidEnableMultiDex) propriedade MSBuild.
AndroidAvoidEmitForPerformance
Uma propriedade booleana que determina se System.Reflection.Emit é "evitada" ou não para melhorar o desempenho de inicialização. Essa propriedade é True por padrão.
O uso de System.Reflection.Emit tem um impacto perceptível no desempenho de inicialização no Android. Esse comportamento é desabilitado por padrão para os seguintes interruptores de recursos:
Switch.System.Reflection.ForceInterpretedInvoke: após a segunda chamada paraMethodInfo.Invoke()ouConstructorInfo.Invoke(), o código é emitido para melhorar o desempenho de chamadas repetidas.Microsoft.Extensions.DependencyInjection.DisableDynamicEngine: após a segunda chamada para recuperar um serviço de um contêiner de injeção de dependência, o código é emitido para melhorar o desempenho de chamadas repetidas.
É desejável na maioria dos aplicativos Android desativar esse comportamento.
Consulte a documentação de Opções de Recursos de Bibliotecas de Classes Base para obter detalhes sobre as opções de recursos disponíveis.
Adicionado no .NET 8.
AndroidBinUtilsPath
Um caminho para um diretório que contém os binutils do Android, como ld, o vinculador nativo e as, o assembler nativo. Essas ferramentas estão incluídas na carga de trabalho do .NET para Android.
O valor padrão é $(MonoAndroidBinDirectory)\binutils\bin\.
AndroidBoundExceptionType
Um valor de cadeia de caracteres que especifica como as exceções devem ser propagadas quando um tipo fornecido pelo .NET para Android implementa um tipo ou interface do .NET em termos de tipos Java, por exemplo Android.Runtime.InputStreamInvoker , e System.IO.Stream, ou Android.Runtime.JavaDictionary e System.Collections.IDictionary.
Java: O tipo de exceção Java original é propagado no estado em que se encontra.Javasignifica que, por exemplo,InputStreamInvokernão implementa corretamente a APISystem.IO.StreamporqueJava.IO.IOExceptionpode ser lançada em vez deStream.Read()System.IO.IOException.System: O tipo de exceção Java original é capturado e encapsulado em um tipo de exceção .NET apropriado.Systemsignifica que, por exemplo,InputStreamInvokerimplementaSystem.IO.Streamcorretamente eStream.Read()não lançaráJava.IO.IOExceptioninstâncias. (Em vez disso, pode lançar umSystem.IO.IOExceptioncontendo umJava.IO.IOExceptioncomo valor doException.InnerException.)Systemé o valor padrão.
InterfacesVinculadasDoAndroidContêmConstantes
Uma propriedade booleana que determina se as constantes de associação em interfaces terão suporte ou se a solução alternativa de criar uma IMyInterfaceConsts classe será usada.
O valor padrão é True.
InterfacesLigadasAoAndroidContêmMétodosEstáticosEDefault
Uma propriedade booleana que indica se os membros padrão e estáticos nas interfaces terão suporte ou uma solução alternativa antiga de criar uma classe irmã contendo membros estáticos como abstract class MyInterface.
O valor padrão é True no .NET 6 e False para sistemas legados.
AndroidBoundInterfacesContainTypes
Uma propriedade booleana que indica se os tipos aninhados em interfaces terão suporte ou a solução alternativa de criar um tipo não aninhado como IMyInterfaceMyNestedClass.
O valor padrão é True no .NET 6 e False para legado.
PacoteDeAplicaçãoDeConstruçãoDoAndroid
Um valor booliano que indica se o pacote (.apk deve ser criado e assinado). Definir esse valor como True é equivalente a usar o
SignAndroidPackage construir destino.
Essa propriedade é False por padrão.
ArquivoDeConfiguraçãoDoPacoteAndroid
Especifica um nome de arquivo a ser usado como um arquivo de configuração para bundletool na porção de compilação de um Android App Bundle. Esse arquivo controla alguns aspectos de como os APKs são gerados a partir do pacote, como em quais dimensões o pacote é dividido para produzir APKs.
O .NET para Android define algumas dessas configurações automaticamente, incluindo a lista de extensões de arquivo a serem deixadas descompactadas.
Essa propriedade só será relevante se $(AndroidPackageFormat) estiver definida como aab.
AndroidBundleToolExtraArgs
Especifica as opções de linha de comando a serem passadas para o comando bundletool ao criar pacotes de aplicativos.
AndroidClassParser
Uma propriedade de cadeia de caracteres que controla como .jar os arquivos são analisados. Entre os valores possíveis estão:
class-parse: usa
class-parse.exepara analisar o código de bytes Java diretamente, sem a assistência de uma JVM.jar2xml: esse valor está obsoleto e não é mais suportado.
AndroidCodegenTarget
Uma propriedade de cadeia de caracteres que controla a ABI de destino de geração de código. Entre os valores possíveis estão:
XamarinAndroid: esse valor está obsoleto e não tem mais suporte.
XAJavaInterop1: usar Java.Interop para invocações de JNI. Assemblies de vinculação usando
XAJavaInterop1somente podem ser compiladas e executadas com o Xamarin.Android 6.1 ou posterior. O Xamarin.Android 6.1 e os posteriores associamMono.Android.dllcom esse valor.JavaInterop1: valor experimental, atualmente o padrão para o runtime NativeAOT.
O valor padrão é XAJavaInterop1.
AndroidCreatePackagePerAbi
Uma propriedade booleana que determina se um conjunto de arquivos - um por ABI especificado em $(AndroidSupportedAbis)--deve ser criado em vez de ter suporte para todas as ABIs em um único .apk.
Consulte também o guia Como criar APKs específicos da ABI.
CriaçãoDeArquivoDeMapaProguardParaAndroid
Uma propriedade booleana que controla se um arquivo de mapeamento do ProGuard é gerado como parte do processo de compilação.
Adicionar o seguinte ao csproj fará com que o arquivo seja gerado e usará a AndroidProguardMappingFile propriedade para controlar o local do arquivo de mapeamento final.
<AndroidCreateProguardMappingFile>True</AndroidCreateProguardMappingFile>
Ao criar arquivos .aab, o arquivo de mapeamento é incluído automaticamente em seu pacote. Não há necessidade de carregá-lo na Google Play Store manualmente. Ao usar arquivos .apk, o AndroidProguardMappingFile precisará ser carregado manualmente.
O valor padrão é True ao usar $(AndroidLinkTool)=r8.
AndroidDebugKeyAlgorithm
Especifica o algoritmo padrão a ser usado para o debug.keystore. O valor padrão é RSA.
ValidadeDaChaveDeDebugDoAndroid
Especifica a validade padrão a ser usada para o debug.keystore. O valor padrão é 10950 ou 30 * 365 ou .30 years
AndroidDebugStoreType
Especifica o formato de arquivo de armazenamento de chaves a ser usado para o debug.keystore. O padrão é pkcs12.
AndroidDeviceUserId
Permite implantar e depurar o aplicativo em contas de convidado ou de trabalho. O valor é o uid valor que você obtém do seguinte comando adb:
adb shell pm list users
O comando acima retornará os seguintes dados:
Users:
UserInfo{0:Owner:c13} running
UserInfo{10:Guest:404}
O uid é o primeiro valor inteiro. Na saída acima, eles são 0 e 10.
AndroidDexTool
Uma propriedade do tipo enumeração com um valor válido de d8.
Anteriormente, havia suporte para um valor de dx no Xamarin.Android.
Indica qual compilador dex do Android é usado durante o processo de build do .NET para Android.
O valor padrão é d8. Veja nossa documentação sobre D8 e R8.
AndroidEnableDesugar
Uma propriedade booleana que determina se desugar está habilitada. No momento, o Android não oferece suporte a todos os recursos do Java 8, e o conjunto de ferramentas padrão implementa os novos recursos de linguagem executando transformações de bytecode, chamadas desugar, na saída do javac compilador. O valor padrão é False se usar $(AndroidDexTool)=dx e True se usar $(AndroidDexTool)=d8.
AndroidAtivarGooglePlayStoreVerificações
Uma propriedade bool que permite que os desenvolvedores desativem as seguintes verificações da Google Play Store: XA1004, XA1005 e XA1006. Desativar essas verificações é útil para desenvolvedores que não estão direcionados para a Google Play Store e não desejam efetuá-las.
AndroidEnableMarshalMethods
Uma propriedade bool, que determina se os métodos de marshal LLVM estão habilitados ou não.
Os métodos de marshalling do LLVM são uma otimização para a inicialização de aplicativos que utiliza pontos de entrada nativos para o registro de métodos Java native.
Essa propriedade é falsa por padrão.
Adicionado no .NET 8.
AndroidEnableMultiDex
Uma propriedade booleana que determina se o suporte a multi-dex será ou não utilizado no arquivo final .apk.
Essa propriedade é False por padrão.
AndroidEnableProfiler
Sinônimo da propriedade $(EnableDiagnostics).
Necessário para usar dotnet-trace ou dotnet-gcdump em aplicativos Android. Se definido como true, ele inclui o componente de diagnóstico Mono no aplicativo. Esse componente é a libmono-component-diagnostics_tracing.so biblioteca nativa.
Essa propriedade é False por padrão.
AndroidEnableObsoleteOverrideInheritance
Uma propriedade booleana que determina se os métodos vinculados herdam automaticamente atributos de métodos que eles substituem.
O suporte para essa propriedade foi adicionado no .NET 8.
Essa propriedade é True por padrão.
AndroidEnablePreloadAssemblies
Uma propriedade booleana que controla se todos os assemblies gerenciados agrupados no pacote de aplicativos são carregados durante a inicialização do processo ou não.
Quando definido como True, todos os assemblies agrupados dentro do pacote de aplicativos serão carregados durante a inicialização do processo, antes que qualquer código do aplicativo seja invocado.
Quando definido como False, os assemblies somente serão carregados conforme necessário.
Carregar assemblies conforme necessário permite um início mais rápido dos aplicativos e também é mais consistente com a semântica do .NET para desktop.
Para ver a economia de tempo, defina a Propriedade do Sistema debug.mono.log para incluir timing e procure a mensagem Finished loading assemblies: preloaded dentro de adb logcat.
Aplicativos ou bibliotecas, que usam injeção de dependência, podem exigir que essa propriedade seja True se, por sua vez, exigirem que AppDomain.CurrentDomain.GetAssemblies() retornem todos os assemblies dentro do pacote de aplicativos, mesmo que o assembly não fosse necessário de outra forma.
Por padrão, esse valor é False.
AndroidEnableProfiledAot
Uma propriedade booleana que determina se os perfis AOT são usados ou não durante a compilação Ahead-of-Time.
Os perfis estão listados em
@(AndroidAotProfile) grupo de itens. Este ItemGroup contém perfis padrão. Ele pode ser substituído removendo o(s) existente(s) e adicionando seus próprios perfis AOT.
Essa propriedade é False por padrão.
AndroidEnableRestrictToAttributes
Uma propriedade do tipo enumeração com valores válidos de obsolete e disable.
Quando definido como obsolete, os tipos e membros marcados com a anotação androidx.annotation.RestrictToJava ou em pacotes Java não exportados serão marcados com um [Obsolete] atributo na associação C#.
Esse [Obsolete] atributo tem uma mensagem descritiva explicando que o proprietário do pacote Java considera a API "interna" e adverte contra seu uso.
Esse atributo também tem um código XAOBS001 de aviso personalizado para que possa ser suprimido independentemente da API obsoleta "normal".
Quando definido como disable, a API será gerada normalmente, sem atributos adicionais. (Esse é o mesmo comportamento de antes do .NET 8.)
A adição [Obsolete] de atributos em vez de remover automaticamente a API foi feita para preservar a compatibilidade da API com os pacotes existentes. Se você preferir, em vez disso, remover membros que tenham a @RestrictTo anotação ou estejam em pacotes Java não exportados, você pode usar Arquivos de Transformação além dessa propriedade para evitar que esses tipos sejam vinculados:
<remove-node path="//*[@annotated-visibility]" />
O suporte para essa propriedade foi adicionado no .NET 8.
Essa propriedade é definida como obsolete por padrão.
AndroidEnableSGenConcurrent
Uma propriedade booleana que determina se o coletor de GC simultâneo do Mono será usado ou não.
Essa propriedade é False por padrão.
AndroidErrorOnCustomJavaObject
Uma propriedade booleana que determina se os tipos podem implementar Android.Runtime.IJavaObjectsem também herdar de Java.Lang.Object ou Java.Lang.Throwable:
class BadType : IJavaObject {
public IntPtr Handle {
get {return IntPtr.Zero;}
}
public void Dispose()
{
}
}
Quando True, esses tipos gerarão um erro XA4212, caso contrário, um aviso XA4212 será gerado.
Essa propriedade é True por padrão.
AndroidExplicitCrunch
Não há mais suporte para essa propriedade.
AndroidExtraAotOptions
Uma propriedade de cadeia de caracteres que permite passar opções para o compilador Mono durante a Aot tarefa para projetos que têm $(AndroidEnableProfiledAot) ou $(AotAssemblies) definidos como true.
O valor da cadeia de caracteres da propriedade é adicionado ao arquivo de resposta ao chamar o compilador cruzado Mono.
Em geral, essa propriedade deve ser deixada em branco, mas em determinados cenários especiais ela pode fornecer flexibilidade útil.
A $(AndroidExtraAotOptions) propriedade é diferente da propriedade relacionada $(AndroidAotAdditionalArguments) ; $(AndroidAotAdditionalArguments) coloca argumentos separados por vírgula --aot na opção do compilador Mono.
$(AndroidExtraAotOptions) em vez disso, passa opções separadas por espaço autônomas completas, como --verbose ou --debug para o compilador.
AndroidFastDeploymentType
Uma : lista de valores separados por dois pontos para controlar quais tipos podem ser implantados no diretório de Implantação Rápida no dispositivo de destino quando a $(EmbedAssembliesIntoApk) propriedade MSBuild for False. Se um recurso é implantado rapidamente, ele não é inserido no .apk gerado, o que pode acelerar o tempo de implantação. (Quanto mais rapidamente for implantado, menos frequentemente será necessário reconstruir o .apk, e o processo de instalação poderá ser mais ágil.) Os valores válidos incluem:
-
Assemblies: implantar os assemblies do aplicativo. -
Dexes: Implante.dexarquivos, bibliotecas nativas e mapas de tipos. ODexesvalor só pode ser usado em dispositivos com Android 4.4 ou posterior (API-19).
O valor padrão é Assemblies.
O suporte para recursos e ativos de implantação rápida por meio desse sistema foi removido no commit f0d565fe. Isso ocorreu porque exigia o uso de APIs obsoletas para funcionar.
**O suporte para esse recurso foi removido no .NET 9
Experimental.
AndroidFragmentType
Especifica o tipo padrão totalmente qualificado a ser usado para todos os elementos de layout <fragment> ao gerar o código de vínculos de layout. O valor padrão é o tipo padrão do Android Android.App.Fragment .
AndroidGenerateJniMarshalMethods
Uma propriedade bool que permite a geração de métodos JNI marshal como parte do processo de compilação. Isso reduz muito o System.Reflection uso no código auxiliar de associação.
O valor padrão é False. Se os desenvolvedores desejarem usar o novo recurso de métodos de marshal JNI, eles podem definir
<AndroidGenerateJniMarshalMethods>True</AndroidGenerateJniMarshalMethods>
em seu .csproj. Como alternativa, forneça a propriedade na linha de comando por meio de
-p:AndroidGenerateJniMarshalMethods=True
Experimental. O valor padrão é False.
AndroidGenerateJniMarshalMethodsAdditionalArguments
Uma propriedade de cadeia de caracteres que pode ser usada para adicionar parâmetros à jnimarshalmethod-gen.exe invocação e é útil para depuração, de modo que opções como -v, -d, ou --keeptemp possam ser usadas.
O valor padrão é uma cadeia de caracteres vazia. Ele pode ser definido no .csproj arquivo ou na linha de comando. Por exemplo:
<AndroidGenerateJniMarshalMethodsAdditionalArguments>-v -d --keeptemp</AndroidGenerateJniMarshalMethodsAdditionalArguments>
ou:
-p:AndroidGenerateJniMarshalMethodsAdditionalArguments="-v -d --keeptemp"
AndroidGenerateLayoutBindings
Habilita a geração de código de layout no code-behind se configurado para `true` ou desabilita completamente se configurado para `false`.
O valor padrão é false.
AndroidGenerateResourceDesigner (Gerador de Recursos do Android)
O valor padrão é true. Quando definido como false, desativa a geração de Resource.designer.cs.
AndroidHttpClientHandlerType
Controla a implementação padrão System.Net.Http.HttpMessageHandler que será usada pelo System.Net.Http.HttpClient construtor padrão. O valor é um nome de tipo qualificado pelo assembly de uma subclasse HttpMessageHandler, adequado para usar com System.Type.GetType(string).
No .NET 6 e mais recente, essa propriedade tem efeito somente quando usada em conjunto com $(UseNativeHttpHandler)=true.
Os valores mais comuns para essa propriedade são:
Xamarin.Android.Net.AndroidMessageHandler: Use as APIs Java do Android para realizar requisições HTTP. É semelhante ao legadoXamarin.Android.Net.AndroidClientHandlercom várias melhorias. Ele suporta HTTP 1.1 e TLS 1.2. É o manipulador de mensagens HTTP padrão.System.Net.Http.SocketsHttpHandler, System.Net.Http: o manipulador de mensagens padrão no .NET. Ele suporta HTTP/2, TLS 1.2 e é o manipulador de mensagens HTTP recomendado para usar com Grpc.Net.Client. Esse valor é equivalente a$(UseNativeHttpHandler)=false.Unset / a cadeia de caracteres vazia, que é equivalente a
System.Net.Http.HttpClientHandler, System.Net.HttpCorresponde à opção Padrão nas páginas de propriedades do Visual Studio.
O novo assistente de projeto seleciona essa opção para novos projetos quando a Versão mínima do Android está configurada como Android 4.4.87 ou mais antiga no Visual Studio ou quando Plataformas de destino está definido como Desenvolvimento Moderno ou Máxima Compatibilidade no Visual Studio para Mac.
System.Net.Http.HttpClientHandler, System.Net.Http: Use o gerenciadoHttpMessageHandler.Corresponde à opção Gerenciado nas páginas de propriedades do Visual Studio.
Observação
No .NET 6, o tipo especificado não deve ser Xamarin.Android.Net.AndroidClientHandler or System.Net.Http.HttpClientHandler ou herdar de nenhuma dessas classes. Se você estiver migrando do Xamarin.Android "clássico", use o AndroidMessageHandler ou derive seu manipulador personalizado a partir dele.
Observação
O suporte para a $(AndroidHttpClientHandlerType) propriedade funciona definindo a XA_HTTP_CLIENT_HANDLER_TYPE variável de ambiente.
Um $XA_HTTP_CLIENT_HANDLER_TYPE valor encontrado em um arquivo com uma ação de Build de
@(AndroidEnvironment) terá precedência.
AndroidIgnoreAllJniPreload
Um valor booliano que, se definido como true, isenta todas as bibliotecas JNI nativas de serem pré-carregadas na inicialização do aplicativo. Por padrão, todas essas bibliotecas serão carregadas pelo runtime mais cedo durante a inicialização do aplicativo, a fim de garantir a inicialização adequada. No entanto, em alguns casos, pode não ser o comportamento desejado e essa propriedade permite desabilitá-lo efetivamente.
Algumas bibliotecas de estrutura que devem ser carregadas na inicialização do aplicativo não serão afetadas por essa propriedade.
Consulte também @(AndroidNativeLibraryNoJniPreload) uma forma mais detalhada de isentar bibliotecas do mecanismo de pré-carregamento.
AndroidIncludeWrapSh
Um valor booleano que indica se o script wrapper do Android (wrap.sh) deve ser empacotado no APK. O valor padrão é false porque o script wrapper pode influenciar significativamente a maneira como o aplicativo é iniciado e funciona e o script deve ser incluído somente quando necessário, por exemplo, ao depurar ou alterar o comportamento de inicialização/tempo de execução do aplicativo.
O script é adicionado ao projeto usando o
@(AndroidNativeLibrary) build action, porque está colocado no mesmo diretório que as bibliotecas nativas específicas para a arquitetura e deve ser nomeado wrap.sh.
A maneira mais fácil de especificar o caminho para o wrap.sh script é colocá-lo em um diretório com o nome da arquitetura de destino. Essa abordagem funcionará se você tiver apenas uma wrap.sh por arquitetura:
<AndroidNativeLibrary Include="path/to/arm64-v8a/wrap.sh" />
No entanto, se o seu projeto precisar de mais de um wrap.sh por arquitetura, para finalidades diferentes, essa abordagem não funcionará.
Em vez disso, nesses casos, o nome pode ser especificado usando os Link metadados do AndroidNativeLibrary:
<AndroidNativeLibrary Include="/path/to/my/arm64-wrap.sh">
<Link>lib\arm64-v8a\wrap.sh</Link>
</AndroidNativeLibrary>
Se os Link metadados forem usados, o caminho especificado em seu valor deverá ser um caminho de biblioteca nativo específico da arquitetura, relativo ao diretório raiz do APK. O formato do caminho é lib\ARCH\wrap.sh onde ARCH pode ser um dos seguintes:
arm64-v8aarmeabi-v7ax86_64x86
AndroidIncluirPacotesDeAtivosNoPacote
Essa propriedade controla se uma compilação de Asset Packs é automaticamente incluída no arquivo final .aab. O padrão será true.
Em certos casos, o usuário pode querer liberar uma liberação provisória. Nesses casos, o usuário não precisa atualizar o pacote de ativos. Especialmente se o conteúdo do pacote de ativos não tiver sido alterado. Essa propriedade permite que o usuário ignore os pacotes de ativos se eles não forem necessários.
Incluído no .NET 9
AndroidInstallJavaDependencies
O valor padrão é true para builds de linha de comando. Quando definido como true, permite a instalação do Java SDK ao executar o <InstallAndroidDependencies/> destino.
O suporte para essa propriedade foi adicionado no .NET 9.
AndroidJavadocVerbosidade
Especifica quão "detalhados" os comentários de documentação XML do C# devem ser ao importar a documentação do Javadoc em projetos de vinculação.
Requer o uso do
@(JavaSourceJar) construir ação.
A $(AndroidJavadocVerbosity) propriedade é semelhante a enumeração, com valores possíveis de full ou intellisense:
-
intellisense: Emite apenas os comentários XML:<exception/>,<param/>,<returns/>,<summary/>. -
full: Emitaintellisenseelementos, bem como<remarks/>,<seealso/>, e qualquer outra coisa que seja suportada.
O valor padrão é intellisense.
AndroidKeyStore
Um valor booliano que indica se as informações de assinatura personalizadas devem ser usadas. O valor padrão é False, que significa que a chave de assinatura de depuração padrão será usada para assinar pacotes.
AndroidLaunchActivity
A atividade do Android para ser iniciada.
AndroidLinkMode
Especifica qual tipo de vinculação deve ocorrer em assemblies contidos no pacote Android. Usado somente em projetos de aplicativo Android. O valor padrão é SdkOnly. Os valores válidos são:
None: nenhuma tentativa de vinculação ocorrerá.
SdkOnly: a vinculação ocorrerá apenas nas bibliotecas de classe base, não nos assemblies do usuário.
Full: A linkagem ocorrerá nas bibliotecas de classe base e nos assemblies do usuário.
Observação
o uso de um valor
AndroidLinkModedefinido como Full normalmente resulta em aplicativos com falha, principalmente quando a reflexão é usada. Evite isso, a menos que você realmente saiba o que está fazendo.
<AndroidLinkMode>SdkOnly</AndroidLinkMode>
AndroidLinkResources
Quando true, o sistema de compilação vinculará os tipos aninhados da classe Resource.Designer.cs Resource em todos os assemblies. O código IL que usa esses tipos será atualizado para usar os valores diretamente em vez de acessar campos.
Vincular os tipos aninhados pode ter um pequeno impacto na redução do tamanho do apk e também pode ajudar no desempenho da inicialização. Somente builds de "Release" são vinculados.
Experimental. Projetado apenas para funcionar com código como
var view = FindViewById(Resources.Ids.foo);
Quaisquer outros cenários (como reflexão) não serão suportados.
AndroidLinkPular
Especifica uma lista delimitada por ponto-e-vírgula (;) de nomes de assembly, sem extensões de arquivo, de assemblies que não devem ser vinculados. Usado somente em projetos de aplicativo Android.
<AndroidLinkSkip>Assembly1;Assembly2</AndroidLinkSkip>
AndroidLinkTool
Uma propriedade de estilo enumeração com valores válidos de proguard ou r8. Indica qual redutor de código é usado para o código Java. O valor padrão é uma string vazia, ou proguard se $(AndroidEnableProguard) for True. Veja nossa documentação sobre D8 e R8.
AndroidLintEnabled
Uma propriedade bool que permite que o desenvolvedor execute a ferramenta Android lint como parte do processo de empacotamento.
Quando $(AndroidLintEnabled)=True, as seguintes propriedades são usadas:
As seguintes ações de compilação também podem ser usadas:
Confira a Ajuda do Lint para obter mais detalhes sobre as ferramentas lint do Android.
Problemas do AndroidLintEnabled
Uma propriedade de string que é uma lista separada por vírgulas de problemas de lint a serem habilitados.
Usado apenas quando $(AndroidLintEnabled)=True.
AndroidLintDisabledIssues (questões desabilitadas pelo Android Lint)
Uma propriedade de string que é uma lista de problemas de lint a serem desabilitados, separada por vírgulas.
Usado apenas quando $(AndroidLintEnabled)=True.
AndroidLintCheckIssues
Uma propriedade de string que é uma lista separada por vírgulas de problemas de lint a serem verificados.
Usado apenas quando $(AndroidLintEnabled)=True.
Observação: somente esses problemas serão verificados.
AndroidManagedSymbols
Uma propriedade booleana que controla a geração de pontos de sequência, permitindo que as informações de nome de arquivo e número de linha sejam extraídas de rastreamentos da pilha Release.
AndroidManifest
Especifica um nome de arquivo para usar como modelo do AndroidManifest.xml do aplicativo.
Durante o build, quaisquer outros valores necessários serão mesclados para produzir o AndroidManifest.xml propriamente dito.
O $(AndroidManifest) deve conter o nome do pacote no atributo /manifest/@package.
AndroidManifestMerger
Especifica a implementação para mesclar arquivos AndroidManifest.xml . Essa é uma propriedade de estilo de enumeração em que legacy seleciona a implementação original do C# e manifestmerger.jar seleciona a implementação Java do Google.
O valor padrão é atualmente manifestmerger.jar. Se você quiser usar a versão antiga, adicione o seguinte ao seu csproj
<AndroidManifestMerger>legacy</AndroidManifestMerger>
A fusão do Google permite o suporte para xmlns:tools="http://schemas.android.com/tools", conforme descrito na documentação do Android.
AndroidManifestMergerExtraArgs
Uma variável de tipo string para fornecer argumentos para a ferramenta de documentação do Android.
Se você quiser um resultado detalhado da ferramenta, você pode adicionar o seguinte ao .csproj.
<AndroidManifestMergerExtraArgs>--log VERBOSE</AndroidManifestMergerExtraArgs>
AndroidManifestType
Uma propriedade de estilo enumeração com valores válidos de Xamarin ou GoogleV2.
Isso controla qual repositório é usado pelo
InstallAndroidDependencies target para determinar quais pacotes e versões de pacotes do Android estão disponíveis e podem ser instalados.
Xamarin é o repositório Lista Aprovada (Recomendado) no Gerenciador de SDK do Visual Studio.
GoogleV2 é o repositório Lista Completa (Sem Suporte) no Gerenciador de SDK do Visual Studio.
Se $(AndroidManifestType) não estiver definido, então Xamarin é usado.
AndroidManifestPlaceholders
Uma lista separada por ponto-e-vírgula de pares de substituição de chave-valor para AndroidManifest.xml, onde cada par tem o formato key=value.
Por exemplo, um valor de propriedade de assemblyName=$(AssemblyName) define um espaço reservado ${assemblyName} que pode então aparecer em AndroidManifest.xml:
<application android:label="${assemblyName}"
Isso fornece uma maneira de inserir variáveis do processo de compilação no arquivo AndroidManifest.xml .
AndroidMultiDexClassListExtraArgs
Uma propriedade de string que permite que os desenvolvedores passem argumentos para o com.android.multidex.MainDexListBuilder ao gerar o multidex.keep arquivo.
Um caso específico é se você estiver recebendo o erro a seguir durante a compilação de dx.
com.android.dex.DexException: Too many classes in --main-dex-list, main dex capacity exceeded
Se você estiver recebendo esse erro, poderá adicionar o seguinte ao .csproj.
<DxExtraArguments>--force-jumbo </DxExtraArguments>
<AndroidMultiDexClassListExtraArgs>--disable-annotation-resolution-workaround</AndroidMultiDexClassListExtraArgs>
o que permitirá que a dx etapa seja bem-sucedida.
AndroidPackageFormat
Uma propriedade de estilo enumeração com valores válidos de apk ou aab. Indica se você deseja empacotar o aplicativo Android como um arquivo APK ou Android App Bundle. Os Pacotes de Aplicativos são um novo formato para builds de Release destinados à submissão no Google Play. O valor padrão é apk.
Quando $(AndroidPackageFormat) é definido como aab, outras propriedades do MSBuild são definidas, que são necessárias para o Lote de Aplicativo do Android:
-
$(AndroidUseAapt2)éTrue. -
$(AndroidUseApkSigner)éFalse. -
$(AndroidCreatePackagePerAbi)éFalse.
Essa propriedade será obsoleta no .net 6. Os usuários devem mudar para a versão mais recente AndroidPackageFormats.
Formatos de pacote Android
Uma propriedade delimitada por ponto-e-vírgula com valores válidos de apk e aab.
Indica se você deseja empacotar o aplicativo Android como um arquivo APK ou Android App Bundle. Os Pacotes de Aplicativos são um novo formato para builds de Release destinados à submissão no Google Play.
Ao criar uma compilação de Release, talvez você queira gerar tanto um aab quanto um apk para distribuição em várias lojas.
Definir AndroidPackageFormats como aab;apk resultará na geração de ambos. Configurar AndroidPackageFormats para aab ou apk gerará apenas um arquivo.
O valor padrão é aab;apk apenas para Release compilações.
É recomendável que você continue a usar apenas apk para debugging.
AndroidPackageNamingPolicy
Uma propriedade do tipo enum para especificar os nomes dos pacotes Java do código-fonte Java gerado.
O único valor com suporte é LowercaseCrc64.
AndroidPrepareForBuildDependsOn
Uma propriedade delimitada por ponto-e-vírgula que pode ser usada para estender o processo de compilação do Android. Os alvos do MSBuild adicionados a essa propriedade serão executados no início do build para ambos os tipos de projeto, Aplicativo e Biblioteca. Essa propriedade está vazia por padrão.
Exemplo:
<PropertyGroup>
<AndroidPrepareForBuildDependsOn>MyCustomTarget</AndroidPrepareForBuildDependsOn>
</PropertyGroup>
<Target Name="MyCustomTarget" >
<Message Text="Running target: 'MyCustomTarget'" Importance="high" />
</Target>
AndroidProguardMappingFile
Especifica a -printmapping regra de proteção para r8. Isso significa que o mapping.txt arquivo será produzido na $(OutputPath) pasta. Esse arquivo pode ser usado ao fazer upload de pacotes para a Google Play Store.
Por padrão, esse arquivo é produzido automaticamente ao usar AndroidLinkTool=r8 e gerará o seguinte arquivo $(OutputPath)mapping.txt.
Se você não quiser gerar esse arquivo de mapeamento, poderá usar a AndroidCreateProguardMappingFile propriedade para parar de criá-lo.
Adicione o seguinte em seu projeto
<AndroidCreateProguardMappingFile>False</AndroidCreateProguardMappingFile>
ou use -p:AndroidCreateProguardMappingFile=False na linha de comando.
AndroidD8IgnoreWarnings
Especifica --map-diagnostics warning info a ser passado para d8. O valor padrão é True, mas pode ser definido como False para impor um comportamento mais rigoroso. Consulte o código-fonte D8 e R8 para obter detalhes.
Adicionado no .NET 8.
AndroidR8IgnoreWarnings
Especifica a -ignorewarnings regra de proteção para r8. Isso permite r8 continuar com a compilação dex mesmo se certos avisos forem encontrados. O valor padrão é True, mas pode ser definido como False para impor um comportamento mais rigoroso. Consulte o manual do ProGuard para obter detalhes.
A partir do .NET 8, especifica --map-diagnostics warning info. Consulte o código-fonte D8 e R8 para obter detalhes.
AndroidR8JarPath
O caminho para r8.jar para uso com o compilador e redutor dex r8. O valor padrão é um caminho para a instalação da carga de trabalho do .NET para Android. Para obter mais informações, confira nossa documentação sobre o D8 e R8.
AndroidResgenExtraArgs
Especifica as opções de linha de comando a serem passadas para o comando aapt ao processar ativos e recursos do Android.
AndroidResgenFile
Especifica o nome do arquivo de recurso a ser gerado. O modelo padrão define isso como Resource.designer.cs.
AndroidResourceDesignerClassModifier
Especifica o modificador de classe para a classe intermediária Resource que é gerada. Os valores válidos são public e internal.
Por padrão, isso será public.
Adicionado em .NET 9.
AndroidSdkBuildToolsVersion
O pacote de ferramentas de compilação do SDK do Android fornece as ferramentas aapt e zipalign , entre outras. Várias versões diferentes do pacote de ferramentas de build podem ser instaladas simultaneamente. O pacote de ferramentas de compilação escolhido para empacotamento é determinado verificando e usando a versão de ferramentas de compilação "preferencial", caso esteja presente; se a versão "preferencial" não estiver presente, então é utilizado o pacote de ferramentas de compilação com a versão mais alta entre as instaladas.
A propriedade do MSBuild $(AndroidSdkBuildToolsVersion) contém a versão preferencial das ferramentas de build. O sistema de build do .NET para Android fornece um valor padrão em Xamarin.Android.Common.targets, e o valor padrão pode ser substituído no arquivo de projeto para escolher uma versão alternativa de ferramentas de build, se (por exemplo) o aapt mais recente estiver falhando enquanto uma versão anterior do aapt funcionar.
AndroidSigningKeyAlias
Especifica o alias da chave no armazenamento de chaves. Este é o valor de keytool-alias usado ao criar o repositório de chaves.
AndroidAssinaturaChavePass
Especifica a senha da chave dentro do arquivo de armazenamento de chaves. Esse é o valor digitado quando keytool solicita Insira a senha da chave para $(AndroidSigningKeyAlias).
Essa propriedade também dá suporte a prefixos env: e file: que podem ser usados para especificar uma variável de ambiente ou arquivo que contenha a senha.
Essas opções fornecem uma maneira de impedir que a senha apareça nos logs de build.
Por exemplo, para usar uma variável de ambiente chamada AndroidSigningPassword:
<PropertyGroup>
<AndroidSigningKeyPass>env:AndroidSigningPassword</AndroidSigningKeyPass>
</PropertyGroup>
Para usar um arquivo localizado em C:\Users\user1\AndroidSigningPassword.txt:
<PropertyGroup>
<AndroidSigningKeyPass>file:C:\Users\user1\AndroidSigningPassword.txt</AndroidSigningKeyPass>
</PropertyGroup>
Observação
O env: prefixo não é suportado quando $(AndroidPackageFormat) é definido como aab.
AndroidSigningKeyStore
Especifica o nome do arquivo de armazenamento de chaves criado pelo keytool. Isso corresponde ao valor fornecido à opção keytool -keystore.
AndroidSigningStorePass
Especifica a senha para $(AndroidSigningKeyStore).
Esse é o valor fornecido a keytool ao criar o arquivo de repositório de chaves e ao solicitar Insira a senha do repositório de chaves:.
Essa propriedade também dá suporte a prefixos env: e file: que podem ser usados para especificar uma variável de ambiente ou arquivo que contenha a senha. Essas opções fornecem uma maneira de impedir que a senha apareça nos logs de build.
Por exemplo, para usar uma variável de ambiente chamada AndroidSigningPassword:
<PropertyGroup>
<AndroidSigningStorePass>env:AndroidSigningPassword</AndroidSigningStorePass>
</PropertyGroup>
Para usar um arquivo localizado em C:\Users\user1\AndroidSigningPassword.txt:
<PropertyGroup>
<AndroidSigningStorePass>file:C:\Users\user1\AndroidSigningPassword.txt</AndroidSigningStorePass>
</PropertyGroup>
Observação
O env: prefixo não é suportado quando $(AndroidPackageFormat) é definido como aab.
AndroidSigningPlatformKey
Especifica o arquivo de chave a ser usado para assinar o apk.
Isso só é usado ao criar system aplicativos.
AndroidSigningPlatformCert
Especifica o arquivo de certificado a ser usado para assinar o apk.
Isso só é usado ao criar system aplicativos.
AndroidStripILAfterAOT
Uma propriedade bool que especifica se os corpos dos métodos compilados AOT serão removidos ou não.
O valor padrão é false, e os corpos dos métodos compilados AOT não serão removidos.
Quando definido como true, $(AndroidEnableProfiledAot) é definido como false por padrão.
Isso significa que nas compilações de configuração de versão - nas quais $(RunAOTCompilation) é true por padrão - o AOT está habilitado para tudo.
Isso pode resultar em tamanhos de aplicativos maiores. Esse comportamento pode ser substituído definindo $(AndroidEnableProfiledAot) explicitamente como true dentro do arquivo de projeto.
O suporte experimental para essa propriedade foi adicionado ao .NET 8, removido no .NET 10.
AndroidStripNativeLibraries
Uma propriedade bool que informa o processo de empacotamento para remover símbolos de depuração das bibliotecas compartilhadas nativas (.so arquivos).
O valor padrão é false e os símbolos de depuração, se houver, serão preservados ao empacotar.
AndroidSupportedAbis
Uma propriedade de cadeia de caracteres que contém uma lista de ABIs, delimitada por ponto-e-vírgula, que deve ser incluída no ;.apk.
Os valores compatíveis incluem:
armeabi-v7ax86arm64-v8ax86_64
AndroidTlsProvider
Essa propriedade está obsoleta e não deve ser usada.
AndroidUseAapt2
Esta era uma propriedade Xamarin.Android que não tem efeito no .NET para Android.
aapt2 é sempre usado e não pode ser desabilitado.
AndroidUseApkSigner
Uma propriedade bool que permite que o desenvolvedor use a apksigner ferramenta em vez de jarsigner.
AndroidUseDefaultAotProfile
Uma propriedade bool que permite ao desenvolvedor suprimir o uso dos perfis AOT padrão.
Para suprimir os perfis AOT padrão, defina a propriedade como false.
AndroidUseDesignerAssembly
Uma propriedade bool que controla se o sistema de compilação gerará um _Microsoft.Android.Resource.Designer.dll ao invés de um Resource.Designer.cs arquivo. Os benefícios disso são aplicativos menores e tempo de inicialização mais rápido.
O valor padrão está true no .NET 8.
Como um Autor do NuGet, é recomendável que você forneça três versões do assembly se quiser manter a compatibilidade com versões anteriores.
Um para MonoAndroid, um para net6.0-android e um para net8.0-android. Você pode fazer isso usando o Xamarin.Legacy.Sdk. Isso só será necessário se o projeto de biblioteca NuGet fizer uso de AndroidResource elementos no projeto ou por meio de uma dependência.
<TargetFrameworks>monoandroid90;net6.0-android;net8.0-android</TargetFrameworks>
Como alternativa, desative essa configuração até que o Classic e o net7.0-android tenham sido descontinuados.
Os projetos do .NET 8 que optarem por desativar essa configuração não poderão consumir referências que a usam. Se você tentar usar um assembly que tenha esse recurso habilitado em um projeto que não tenha, você receberá um erro de XA1034 compilação.
Adicionado no .NET 8.
AndroidUseInterpreter
Uma propriedade booleana que faz com que o .apk contenha o interpretador mono, e não o JIT normal.
Experimental.
AndroidUseLegacyVersionCode
Uma propriedade booliana que permite que o desenvolvedor reverta o cálculo versionCode de volta ao seu antigo comportamento anterior ao Xamarin.Android 8.2. Isso deve ser usado SOMENTE por desenvolvedores com aplicativos existentes na Google Play Store. É altamente recomendável que a nova propriedade $(AndroidVersionCodePattern) seja usada.
AndroidUseManagedDesignTimeResourceGenerator
Uma propriedade booleana que mudará as compilações realizadas em tempo de design para usar o analisador de recursos gerenciados, em vez de aapt.
AndroidUseNegotiateAuthentication
Uma propriedade booleana que habilita o suporte para autenticação NTLMv2/Negotiate no AndroidMessageHandler. O valor padrão é Falso.
Funcionalidade adicionada no .NET 7.
AndroidUseSharedRuntime
Essa propriedade está obsoleta e não deve ser usada.
AndroidVersionCode
Uma propriedade do MSBuild que pode ser usada como uma alternativa a /manifest/@android:versionCode no arquivo AndroidManifest.xml. Para ativar esse recurso, você também deve ativar <GenerateApplicationManifest>true</GenerateApplicationManifest>.
Esse será o padrão daqui para frente no .NET 6.
Essa propriedade é ignorada se $(AndroidCreatePackagePerAbi) e $(AndroidVersionCodePattern) forem usados.
@android:versionCode é um valor inteiro que deve ser incrementado para cada versão do Google Play. Consulte a documentação do Android para obter mais detalhes sobre os requisitos do /manifest/@android:versionCode.
PadrãoDeCódigoDeVersãoAndroid
Uma propriedade de string que permite que o desenvolvedor personalize o versionCode no manifesto.
Confira Criar um código de versão para o APK para obter informações sobre como decidir um versionCode.
Alguns exemplos: se abi for armeabi e versionCode no manifesto for 123, {abi}{versionCode} produzirá um versionCode de 1123 quando $(AndroidCreatePackagePerAbi) for True; caso contrário, gerará um valor de 123.
Se abi é x86_64 e versionCode no manifesto é 44. Isso produzirá 544 quando $(AndroidCreatePackagePerAbi) for True; caso contrário, gerará um valor de 44.
Se nós incluíssemos uma cadeia de caracteres de formato de preenchimento esquerdo {abi}{versionCode:0000}, isso produziria 50044 porque estamos aplicando preenchimento esquerdo ao versionCode com 0. Como alternativa, você pode usar o preenchimento decimal, como
{abi}{versionCode:D4} que faz o mesmo que o exemplo anterior.
Somente os formatos de cadeias de caracteres de preenchimento '0' e 'Dx' são compatíveis, já que o valor PRECISA ser um inteiro.
Itens chave pré-definidos
abi – Insere o abi alvo para o aplicativo
- 2 –
armeabi-v7a - 3 –
x86 - 4 –
arm64-v8a - 5 –
x86_64
- 2 –
minSDK – Insere o valor mínimo do SDK com suporte do
AndroidManifest.xmlou11se nenhum estiver definido.versionCode – Usa o código da versão diretamente do
Properties\AndroidManifest.xml.
Você pode definir itens personalizados usando a propriedade $(AndroidVersionCodeProperties) (definida a seguir).
Por padrão o valor será definido como {abi}{versionCode:D6}. Se um desenvolvedor quiser manter o comportamento anterior, você poderá configurar a propriedade $(AndroidUseLegacyVersionCode) como true para substituir o padrão
AndroidVersionCodeProperties
Uma propriedade de cadeia de caracteres que permite ao desenvolvedor definir itens personalizados a serem usados com o $(AndroidVersionCodePattern).
Eles estão na forma de um par key=value. Todos os itens no value devem ser valores inteiros. Por exemplo: screen=23;target=$(_AndroidApiLevel). Como você pode ver, você pode fazer uso de propriedades do MSBuild existentes ou personalizadas na cadeia de caracteres.
ApplicationId
Uma propriedade do MSBuild que pode ser usada como uma alternativa ao /manifest/@package no arquivo AndroidManifest.xml. Para ativar esse recurso, você também deve ativar <GenerateApplicationManifest>true</GenerateApplicationManifest>.
Esse será o padrão daqui para frente no .NET 6.
Consulte a documentação do Android para obter mais detalhes sobre os requisitos do /manifest/@package.
Título da Aplicação
Uma propriedade do MSBuild que pode ser usada como uma alternativa a /manifest/application/@android:label no arquivo AndroidManifest.xml. Para ativar esse recurso, você deve ativar também <GenerateApplicationManifest>true</GenerateApplicationManifest>.
Esse será o padrão daqui para frente no .NET 6.
Consulte a documentação do Android para obter mais detalhes sobre os requisitos do /manifest/application/@android:label.
Versão do Aplicativo
Uma propriedade do MSBuild que pode ser usada como uma alternativa a /manifest/@android:versionName no arquivo AndroidManifest.xml. Para ativar esse recurso, você também deve ativar <GenerateApplicationManifest>true</GenerateApplicationManifest>.
Esse será o padrão daqui para frente no .NET 6.
Consulte a documentação do Android para obter mais detalhes sobre os requisitos do /manifest/@android:versionName.
AotAssemblies
Uma propriedade booleana que determina se os assemblies serão compilados em código nativo antecipadamente ou não e incluídos em aplicativos.
Essa propriedade é False por padrão.
Preterido no .NET 7. Migre para a nova propriedade $(RunAOTCompilation) do MSBuild, pois o suporte a $(AotAssemblies) será removido em uma versão futura.
AProfUtilExtraOptions
Opções extras para passar para aprofutil.
Antes do Build Android Asset Packs
Os destinos do MSBuild listados nessa propriedade serão executados imediatamente antes que os AssetPack itens sejam compilados.
Incluído no .NET 9
AntesGenerateAndroidManifest
Os destinos do MSBuild listados nesta propriedade serão executados diretamente antes de _GenerateJavaStubs.
Configuração
Especifica a configuração de build a ser usada, como "Debug" ou "Release". A propriedade Configuration é usada para determinar os valores padrão de outras propriedades que determinam o comportamento de destino. Configurações adicionais podem ser criadas dentro de seu IDE.
Por padrão, a Debug configuração resultará no
Install e
SignAndroidPackage visa criar um pacote Android menor que requer a presença de outros arquivos e pacotes para operar.
A configuração padrão Release resultará no
Install e
SignAndroidPackage visa criar um pacote Android que seja autônomo e possa ser usado sem instalar outros pacotes ou arquivos.
DebugSymbols
Um valor booleano que determina se o pacote Android é depurável, em conjunto com a propriedade $(DebugType).
Um pacote depurável contém símbolos de depuração, define o //application/@android:debuggable atributo como truee adiciona automaticamente o atributo
INTERNET permissão para que um depurador possa se conectar ao processo. Um aplicativo é depurável se DebugSymbols for TrueeDebugType for a cadeia de caracteres vazia ou Full.
DebugType
Especifica o tipo de símbolos de depuração a serem gerados como parte da compilação, o que também afeta se o aplicativo é depurável. Entre os valores possíveis estão:
Full: os símbolos completos são gerados. Se o
DebugSymbolsA propriedade MSBuild também está definida, então o pacote de aplicativo é depurável.PdbOnly: os símbolos "PDB" são gerados. O pacote de aplicativos não pode ser depurado.
Se DebugType não está definida ou é uma cadeia de caracteres vazia, a propriedade DebugSymbols controla se o Aplicativo é depurável.
Dispositivo
Especifica qual dispositivo ou emulador Android deve ser direcionado ao utilizar dotnet run --device <Device> ou alvos do MSBuild que interagem com dispositivos (como Run, Install, ou Uninstall).
O valor deve ser o número de série completo do dispositivo ou o identificador conforme retornado por adb devices. Por exemplo, se a série do dispositivo for emulator-5554, você deverá usar -p:Device=emulator-5554.
Quando definida, essa propriedade é usada para inicializar a AdbTarget propriedade com o valor -s "<Device>".
Para obter mais informações sobre a seleção do dispositivo, consulte a especificação de seleção de dispositivo do SDK do .NET.
EndereçoDiagnóstico
Um valor fornecido por dotnet-dsrouter, tal como 127.0.0.1, o componente de endereço IP de $(DiagnosticConfiguration) ou $DOTNET_DiagnosticPorts.
Habilita implicitamente o componente de diagnóstico Mono, o que significa que $(EnableDiagnostics)/$(AndroidEnableProfiler) está definido como .true
Usa 127.0.0.1 como padrão.
Configuração de diagnóstico
Um valor fornecido por dotnet-dsrouter, para $DOTNET_DiagnosticPorts, tais como:
127.0.0.1:9000,suspend,connect127.0.0.1:9000,nosuspend,connect
Observe que o caractere , precisará ser escapado com %2c se passado na linha de comando para dotnet build:
dotnet build -c Release -p:DiagnosticConfiguration=127.0.0.1:9000%2csuspend%2cconnect
Isso definirá automaticamente a variável de $DOTNET_DiagnosticPorts ambiente empacotada dentro do aplicativo.
Habilita implicitamente o componente de diagnóstico Mono, o que significa que $(EnableDiagnostics)/$(AndroidEnableProfiler) está definido como .true
DiagnosticListenMode
Um valor fornecido por dotnet-dsrouter, como, por exemplo, o componente de modo de escuta de $(DiagnosticConfiguration) ou $DOTNET_DiagnosticPorts.
Habilita implicitamente o componente de diagnóstico Mono, o que significa que $(EnableDiagnostics)/$(AndroidEnableProfiler) está definido como .true
Usa connect como padrão.
DiagnosticPort
Um valor fornecido por dotnet-dsrouter, como o componente de porta de $(DiagnosticConfiguration) ou $DOTNET_DiagnosticPorts.
Habilita implicitamente o componente de diagnóstico Mono, o que significa que $(EnableDiagnostics)/$(AndroidEnableProfiler) está definido como .true
Usa 9000 como padrão.
DiagnosticSuspend
Um valor booliano fornecido por dotnet-dsrouter , como true/suspend ou false/nosuspend, um componente de $(DiagnosticConfiguration) ou $DOTNET_DiagnosticPorts.
Habilita implicitamente o componente de diagnóstico Mono, o que significa que $(EnableDiagnostics)/$(AndroidEnableProfiler) está definido como .true
Usa false como padrão.
EmbedAssembliesIntoApk
Uma propriedade booliana que determina se os assemblies do aplicativo devem ou não ser inseridos no pacote Application.
Essa propriedade deve ser True para builds de Release e False para builds de Debug. Ele pode precisar estar True em builds de depuração se o Fast Deployment não for compatível com o dispositivo de destino.
Quando essa propriedade é False, então o
$(AndroidFastDeploymentType) A propriedade MSBuild também controla o que será inserido no .apk, o que pode afetar os tempos de implantação e recompilação.
AtivarDiagnóstico
Sinônimo da $(AndroidEnableProfiler) propriedade.
Necessário para usar dotnet-trace ou dotnet-gcdump em aplicativos Android. Se definido como true, ele inclui o componente de diagnóstico Mono no aplicativo. Esse componente é a libmono-component-diagnostics_tracing.so biblioteca nativa.
Essa propriedade é False por padrão.
HabilitarLLVM
Uma propriedade booleana que determina se o LLVM será ou não usado ao compilar assemblies antecipadamente em código nativo.
O Android NDK deve ser instalado para criar um projeto que tenha essa propriedade ativada.
Essa propriedade é False por padrão.
Essa propriedade é ignorada, a menos que a propriedade $(AotAssemblies) do MSBuild seja True.
Habilite Proguard
Uma propriedade booleana que determina se proguard é executado ou não como parte do processo de empacotamento para vincular o código Java.
Essa propriedade é False por padrão.
Quando True, @(ProguardConfiguration) os arquivos serão usados para controlar proguard a execução.
EventSourceSupport
Quando definido como false, desabilita o suporte do EventSource do .NET de aplicativos Android reduzidos. Desabilitar esse recurso impediria que ferramentas de diagnóstico do .NET, como dotnet-counters, funcionassem, mas proporcionaria a vantagem de reduzir o tamanho do aplicativo.
Definido como false por padrão no modo Release, a menos que $(EnableDiagnostics) ou $(AndroidEnableProfiler) estejam habilitados.
GerarManifestoAplicativo
Habilita ou desabilita as seguintes propriedades do MSBuild que emitem valores no arquivo final AndroidManifest.xml :
O valor $(GenerateApplicationManifest) padrão é true.
JavaMaximumHeapSize
Especifica o valor do valor do parâmetro java-Xmx a ser usado ao construir o .dex arquivo como parte do processo de empacotamento. Se não for especificado, a opção -Xmx fornecerá java com um valor de 1G. Foi verificado que isso normalmente é necessário no Windows em comparação com outras plataformas.
Especificar essa propriedade é necessária se o _CompileDexdestino gera um java.lang.OutOfMemoryError.
Personalize o valor alterando:
<JavaMaximumHeapSize>1G</JavaMaximumHeapSize>
Opções Java
Especifica as opções de linha de comando a serem passadas para java ao criar o .dex arquivo.
JarsignerTimestampAuthorityCertificateAlias
Essa propriedade permite especificar um alias no keystore para uma autoridade de registro de data e hora. Consulte a documentação do Java Signature Timestamp Support para obter mais detalhes.
<PropertyGroup>
<JarsignerTimestampAuthorityCertificateAlias>Alias</JarsignerTimestampAuthorityCertificateAlias>
</PropertyGroup>
JarsignerTimestampAuthorityUrl
Essa propriedade permite que você especifique uma URL para um serviço de autoridade de carimbo de data/hora. Isso pode ser usado para garantir que sua .apk assinatura inclua um carimbo de data/hora.
Consulte a documentação do Java Signature Timestamp Support para obter mais detalhes.
<PropertyGroup>
<JarsignerTimestampAuthorityUrl>http://example.tsa.url</JarsignerTimestampAuthorityUrl>
</PropertyGroup>
LinkerDumpDependencies
Uma propriedade bool que permite a geração de um arquivo de dependências do linker. Esse arquivo pode ser usado como entrada para a ferramenta illinkanalyzer.
O arquivo de dependências nomeado linker-dependencies.xml.gz é gravado no diretório do projeto. Em .NET5/6, ele é registrado ao lado dos assemblies vinculados no diretório obj/<Configuration>/android<ABI>/linked.
O valor padrão é Falso.
MandroidI18n
Essa propriedade do MSBuild está obsoleta e não tem mais suporte.
MetricsSupport
Quando definido como false, desabilita o suporte de Métricas do .NET em aplicativos Android reduzidos. Desabilitar esse recurso impediria que APIs, como, por System.Diagnostics.Metrics exemplo, funcionassem, mas em benefício da redução do tamanho do aplicativo.
Definido como false por padrão no modo Release, a menos que $(EnableDiagnostics) ou $(AndroidEnableProfiler) estejam habilitados.
MonoAndroidAssetPrefix
Especifica um prefixo de caminho que é removido do início dos nomes de arquivo com uma ação de Construção de AndroidAsset. Isso é para permitir a alteração do local em que os recursos estão localizados.
O valor padrão é Assets. Altere isso para assets para a estrutura do projeto Java.
MonoAndroidResourcePrefix
Especifica um prefixo de caminho que é removido do início do nome de arquivos com uma ação de compilação de AndroidResource. Isso é para permitir a alteração do local em que os recursos estão localizados.
O valor padrão é Resources. Altere isso para res para a estrutura do projeto Java.
Arquivo MonoSymbol
Observação
Esta era uma propriedade herdada do MSBuild do Xamarin.Android. Não disponível no .NET 6+.
Uma propriedade booleana que controla se são criados artefatos para uso posterior com mono-symbolicate, para extrair informações "reais" de nome de arquivo e número de linha de rastreamentos de pilha de liberação.
Isso é Verdadeiro por padrão para aplicativos de liberação que têm símbolos de depuração ativados: $(EmbedAssembliesIntoApk) é Verdadeiro,
$(DebugSymbols) é Verdadeiro, e
$(Optimize) é Verdadeiro.
RunAOTCompilation (Executar Compilação AOT)
Uma propriedade booleana que determina se os assemblies serão compilados em código nativo antecipadamente ou não e incluídos em aplicativos.
Essa propriedade é False por padrão para compilações Debug e True por padrão para compilações Release.
Essa propriedade do MSBuild substitui a $(AotAssemblies) propriedade do MSBuild do Xamarin.Android. Essa é a mesma propriedade usada para WASM do Blazor.
WaitForExit
Uma propriedade booliana que controla o comportamento de dotnet run ao iniciar aplicativos Android.
Quando $(WaitForExit) não false estiver (o padrão), dotnet run será:
- Iniciar o aplicativo Android
- Fluxo de saída
logcatfiltrado para o processamento do aplicativo - Aguarde a saída do aplicativo ou para que o usuário pressione Ctrl+C
- Forçar a parada do aplicativo quando Ctrl+C for pressionado
Quando $(WaitForExit) for false, dotnet run simplesmente iniciará o aplicativo usando adb shell am start e retornará imediatamente sem esperar o aplicativo sair ou transmitir qualquer saída.
Introduzido no .NET 11.