CommunityToolkit Maui - Module SpeechToText

Ce qui est très fort maintenant avec GitHub c'est que vous pouvez suivre en direct les développements de la Community Open Source.

Donc ce matin, je reprends mes développement avec .NET Maui et je me rends compte que dans CommunityToolkit.Maui.Samples que je n'ai pas la page Pages.Essentials.SpeechToTextPage. Cela signifie que je suis sur la branch main mais que des commits ont été réalisés depuis.

Je me promène dans mon Fork en remontant les commits jusqu'à ce je vois apparaître la Page SpeechToTextPage.xaml. Puis je fais un Checkout et là je vois toutes les différences qui ont conduit à la livraison d'un exemple du module SpeechToText dans CommunityToolkit Maui :

Commit SpeechToText #808 (#1127)

Dans les Changes, je vois tout le code que Vladdislav Antonyuk a ajouté pour livrer le module SpeechToText.

Je ne sais pas vous mais moi, je trouve cela très instructif ....

Ce que j'aimerais faire, c'est isoler ce développement, le comprendre pour intégrer une page SpeechToText dans mon application :

GitHub mabyre - MauiAppToolkit

MauiProgram.cs

Commençons par le commencement la création de l'application Maui dans MauiProgram.cs

Utilisation de :

using CommunityToolkit.Maui.Media;

pour l'ajout des deux services : SpeechToText et TextToSpeech

On vérifie que l'application fonctionne toujours.

Integrate module SpeechToText

La suite dans le GitHub :

GitHub Mabyre - MauiAppToolkit#integrate-speech-to-text

Remarque sur la difficulté de l'exercice ... Le plus dur (long) fut de corriger les erreurs générés par le code auto-généré ... 

Lors du déplacement de la page (view) :

MauiAppToolkit/SpeechToTextPage.xaml

Le code généré par les directives du Xaml est en erreur !? 

Le moyen de s'en sortir (le mien) j'ai modifié les namespace puis je les ai remis les erreurs ont disparues.

Sur un stach de la banche integrate-speeh-to-text vous verrez une tentative de supprimer BasePage.cs et ce n'est pas joli joli.

Pareil, j'ai essayé de renommer BasPage en BaseView qui me paraissait bien plus adapté à mon projet cela ne fonctionne pas. Je me demande s'il n'y a pas une interaction entre ce BasePage et CommunityToolkit.Maui... 

Mais voilà sinon c'était sympathique, ce petit moment de codage...

N'hésitez pas à commenter.




Développement .NET MAUI stabilité de la plateforme de développement

Je développement avec Visual Studio Community 2022 et MAUI le successeur de Xamarin ... Et je vois devant moi la plateforme prendre des initiatives comme ajouter des Using fantaisistes pour compléter le code que je suis en train d'écrire.

Je suis surpris, je trouve cela un peu trop intrusif d'autant que vous ajoutez un using par ci par là mais la plateforme joue aussi beaucoup avec les packages qu'elle installe aussi automatiquement en fonction des projets que vous ouvrez.

Alors tout ceci est-il bien stable ? C'est une question dont je viens d'avoir la réponse.

Trouble shooting using MAUI plateforme

Voici la réponse à la question, la plateforme de développement Microsoft .NET MAUI est-elle stable ?

La plateforme de développement Microsoft .NET MAUI est-elle stable ?
La plateforme de développement Microsoft .NET MAUI est-elle stable ?

Cela fait déjà un petit moment que je trouve les initiatives de la plateforme ... comment dire ... mal à propos. Et ce matin voilà ça y est c'est planté !

Ce matin, j'ai bien peur de retomber dans :

L'Enfer du DotNET !

Alors trouvons des solutions au maintient d'une plateforme stable.

Error dans Xamarin Tools

Pourquoi Xamarin ? Je croyais que l'on en avait plus besoin...

1 - C:\Program Files\dotnet\packs\Microsoft.Android.Sdk.Windows\33.0.46\tools\Xamarin.Android.Aapt2.targets

Une erreur avec Xamarin, alors c'est curieux parce qu'il est stipulé lorsque vous débutez MAUI que c'est le successeur de Xamarin mais qui n'a pas besoin de Xamarin d'ailleurs quand vous installez le Développement .NET MAUI Xamarin est facultatif certainement pour migrer des anciens projets Xamarin vers MAUI.

Xamarin est-il nécessaire à la MAUI Plateforme ?
Xamarin est-il nécessaire à la MAUI Plateforme ?

Une fois de plus je vais trouver la solution mais c'est navrant de constater que ce n'est pas encore sec sec sec tout ça. Il y a surement encore des liens trop ténus avec Xamarin et sa foultitude de tools qui ne fonctionnent pas.

Bien sûr, je vais vous trouver une solution, stay tude.

Erreur NU1105 - Impossible de lire les informations du projet

Voici cette nouvelle instabilité de ma plateforme de développement, en général quand ce genre de message apparaît alors que vous ne pensez pas avoir fait quoi que ce soit, c'est au moins la demi-journée pour trouver la correction sauf si vous avez de la chance. 

Impossible de lire les informations relatives au projet pour 'MauiAppToolkit' :
La séquence contient plusieurs éléments ...

Voici l'erreur du jour, elle je vous assure elle est coton car la solution n'est pas évidente. J'ai un fichier project.assets.json qu in'est pas généré correctement.

Hummm l'erreur Visual Studio qu'elle pue la mmm
Hummm l'erreur Visual Studio qu'elle pue la mmm

Alors que s'est-il passé ? D'après moi c'est d'avoir ouvert la solution avec Visual Studio 2019 qui a commencé à bricoler tenter de faire des mise à jour alors que la Solution MAUI ne peut s'ouvrir qu'avec Visual Studio 2022 !

Je supprime bien sur les .\bin et .\obj rien n'y fait.

Je recherche du côté de la suppression des NuGets dans les répertoire :

C:\Users\Mabyre\.nuget\

Je supprime Tout !

Je regarde dans :

C:\Program Files (x86)\Microsoft SDKs\NuGetPackages

Rien n'a à voir avec Maui ou Community, je ne supprime pas !

C:\Program Files (x86)\Microsoft Visual Studio\Shared\NuGetPackages

Il n'y a rien là dedans !

Alors je vais du côté de : 

Outils -> Options -> Gestionnaire de package NuGet -> Général

Gestionnaire de packages Nugets

Je clique sur :  Effacer tout le stockage NuGet. C'est peut être ça qui à corrigé le problème ...

Dans la fenêtre de sortie :

Effacement du cache HTTP NuGet : C:\Users\Mabyre\AppData\Local\NuGet\v3-cache
Effacement du dossier des packages globaux NuGet : C:\Users\Mabyre\.nuget\packages\
Effacement du cache temporaire NuGet : C:\Users\Mabyre\AppData\Local\Temp\NuGetScratch
Effacement du cache des plug-ins NuGet : C:\Users\Mabyre\AppData\Local\NuGet\plugins-cache
Ressources locales effacées.
========== Fin ==========

Je créé une nouvelle solution en ouvrant directement le fichier .csproj. Je quitte en sauvegardant la solution. 

Puis, une idée de génie je tente d'exécuter quand même la solution malgré les erreurs, voilà ma solution devant moi en train de s'exécuter. Du coup j'aimerais remettre la solution dans le répertoire racine du projet mais voilà :

Error AndroidManifest.xml

Bon voilà c'est corrigé :

GitHub - Mabyre - MauiAppToolkit

Crash de la Plateforme de développement MAUI

Voilà le problème précédent corrigé, qu'un nouveau crash se produit ...

Erreur : ApplicationId 'com.companyname.mauicameramauisample' was not a valid GUID. Windows apps use a GUID for an application ID instead of the reverse domain used by Android and/or iOS apps. Either set the <ApplicationIdGuid> property to a valid GUID or use a condition on <ApplicationId> for Windows apps. MauiCameraMauiSample C:\Program Files\dotnet\packs\Microsoft.Maui.Resizetizer.Sdk\7.0.86\targets\Microsoft.Maui.Resizetizer.targets 655

C:\Program Files\dotnet\packs\Microsoft.Maui.Resizetizer.Sdk\7.0.86\targets\Microsoft.Maui.Resizetizer.targets(655,9): error : ApplicationId 'com.companyname.mauicameramauisample' was not a valid GUID. Windows apps use a GUID for an application ID instead of the reverse domain used by Android and/or iOS apps. Either set the <ApplicationIdGuid> property to a valid GUID or use a condition on <ApplicationId> for Windows apps.

Une petite fenêtre très sympathique VCManagePackage :

Allé encore, cette fois également ça sent mauvais... Bon comme il y a une mise à jour Visual Studio et bien allons y mettons à jour 17.6 en 17.7 je crois.

Erreur NETSDK1112 le pack de runtime pour Microsoft.NETCore.App.Runtime.win-x64 n'a pas été téléchargé. Essayez d'exécuter une restauration NuGet avec le RuntimeIdentifier 'win-x64'. MauiCameraMauiSample C:\Program Files\dotnet\sdk\7.0.304\Sdks\Microsoft.NET.Sdk\targets\Microsoft.NET.Sdk.FrameworkReferenceResolution.targets 448

Un petit coup de PowerShell :

PS>dotnet restore --runtime win-x64

L'erreur Erreur NETSDK1112 est corrigé mais pas l'autre. Pour corriger l'autre j'ai du ajouter :

<ApplicationIdGuid>dafdd4e2-67de-4a3e-9f4f-196e13fb1bd1</ApplicationIdGuid>

Dans le fichier projet .csproj de la solution... rien de moins que de bricoler le fichier .csproj à la mimine.

Erreur AMM0000

Et cela continue !

Erreur AMM0000 uses-sdk:minSdkVersion 19 cannot be smaller than version 21 declared in library C:\Users\Mabyre\Documents\Visual Studio 2022\Samples\MAUI\MauiAppToolkit\MauiAppToolkit\obj\Debug\net7.0-android\lp\133\jl\AndroidManifest.xml as the library might be using APIs not available in 19

Suggestion: use a compatible library with a minSdk of at most 19,

or increase this project's minSdk version to at least 21,

or use tools:overrideLibrary="androidx.security" to force usage (may lead to runtime failures)

Directory 'obj\Debug\net7.0-android\lp\133' is from 'androidx.security.security-crypto.aar'. MauiAppToolkit C:\Users\Mabyre\Documents\Visual Studio 2022\Samples\MAUI\MauiAppToolkit\MauiAppToolkit\obj\Debug\net7.0-android\AndroidManifest.xml 46

J'avoue cela me fatigue un peu ...

Du coup j'ai supprimé la ligne :

<uses-sdk />

Du fichier :

\MauiAppToolkit\Platforms\Android\AndroidManifest.xml

Et ça fonctionne à nouveau.

.NET 6.0 & .NET 7.0

Ce matin, je travaille sur mon MAUI Application Toolkit pas de soucis. Et puis, je ne sais pour qu'elle raison saugrenue, j'ai eu envie d'essayer le projet suivant :

https://github.com/henduck/MAUINewsApp.git

Je clone, j'ouvre la solution, je laisse la génération se dérouler et

BOOUUUUMMMMMMM !!!

Erreur	NETSDK1005	Le fichier de composants '\Visual Studio 2022\Samples\MAUI\MauiAppToolkit\MauiAppToolkit\obj\project.assets.json' n'a aucune cible pour 'net7.0-windows10.0.19041.0'
Erreur NETSDK1005 Le fichier de composants '\Visual Studio 2022\Samples\MAUI\MauiAppToolkit\MauiAppToolkit\obj\project.assets.json' n'a aucune cible pour 'net7.0-windows10.0.19041.0'

Message d'erreur :

Erreur NETSDK1005 Le fichier de composants '\MauiAppToolkit\obj\project.assets.json' n'a aucune cible pour 'net7.0-windows10.0.19041.0'. Vérifiez que la restauration s'est exécutée et que vous avez inclus 'net7.0-windows10.0.19041.0' dans TargetFrameworks pour votre projet. MauiAppToolkit C:\Program Files\dotnet\sdk\7.0.304\Sdks\Microsoft.NET.Sdk\targets\Microsoft.PackageDependencyResolution.targets

Ça fait toujours bien dans le SEO du post de mettre le message d'erreur !

Je suppose que l'erreur fut générée par la restauration du projet en .NET 6.0 alors que le projet MauiAppToolkit est déjà en .NET 7.0.

Je découvre :

GitHub Redth - dotnet-maui-check

J'exécute tout ce qu'il faut ça prend du temps plusieurs minutes :

Exécution de .NET MAUI Check
Exécution de .NET MAUI Check 

Dommage on dirait pourtant que tout va bien mais rien à faire :

Erreur NETSDK1005 Le fichier de composants 'C:\Users\Mabyre\Documents\Visual Studio 2022\Samples\MAUI\MauiAppToolkit\MauiAppToolkit\obj\project.assets.json' n'a aucune cible pour 'net7.0-android'. Vérifiez que la restauration s'est exécutée et que vous avez inclus 'net7.0-android' dans TargetFrameworks pour votre projet. MauiAppToolkit C:\Program Files\dotnet\sdk\7.0.304\Sdks\Microsoft.NET.Sdk\targets\Microsoft.PackageDependencyResolution.targets 266

Et puis à force de lire ce message d'erreur 'restore' m'enfin oui bien sûr il y a la commande :

Commande PowerShell > DotNET Restore

PS C:\Users\Mabyre\Documents\Visual Studio 2022\Samples\MAUI\MauiAppToolkit>dotnet restore

Cela prend du temps mais au bout PowerShell me répond "Restauration effectuée en 3,55 min et cette fois cela y est mon application fonctionne à nouveau.

Have a nice day! I'll go to the beach!

Découvrir rapidement MSTest et faire du TDD

Alors depuis toujours je fais des Tests, des TU, des TI et même des TV, évidemment ;) Mais après la découverte du Software Craftsmanship et ce concept de développement logiciel, me voici en train de me remettre à jour sur les Tests.

Pour moi, il n'y a aucune raison de ne pas choisir MSTest V2.

Voici mon projet MSTest de démarrage :

GitHub - dotnet/samples/tree/main/core/getting-started/unit-testing-using-mstest

J'ouvre la solution : unit-testing-using-mstest.sln

En suite, je lance les trois commandes pour installer les packages dans PowerShell :

PS>Install-Package MSTest.TestAdapter
PS>Install-Package MSTest.TestFramework
PS>Install-Package Microsoft.NET.Test.Sdk

Une fois les packages installés, tout se passe dans le menu Test de Visual Studio :

MSTest avec Visual Studio
MSTest avec Visual Studio

Tout se trouve dans la fenêtre suivante :

MSTest exécution dans la fenêtre de Visual Studio
MSTest exécution dans la fenêtre de Visual Studio

En 1 : Je trouve les Annotations et notamment DataRow qui indique simplement que le test sera exécuté avec comme paramètre la valeur -1 puis 0 puis 1.

En 2 : J'exécute tous les tests, ils sont au vert.

Lambdatest - MSTest Framework Tutorial Using .Net Core

Et voilà, c'est parti pour le TDD ! Maintenant, quand je vais concevoir mon soft, je vais d'abord penser aux tests qu'est ce que je voudrais que mon logiciel passe comme tests.

Don't forget to go to the beach!

MAUI - Comment déployer mon application sur les différentes plateformes

Je développe mon application MAUI depuis quelques jours déjà. Je lance son exécution depuis Visual Studio mais j'ai remarqué un exécutable. Je me retrouve avec un EXE sur lequel quand je clique dessus... Rien ! Absolument rien...

Je regarde Ici :

Microsoft Learn - .NET MAUI - Déboggage sur Windows

Et rien le mode développeur était déjà activé sur ma machine ;-)

Pour développer n'oubliez pas ce cocher le "Mode développeur"
Pour développer n'oubliez pas ce cocher le "Mode développeur"

Alors avec MAUI quand je clique sur l'EXE il ne se passe rien.... Je tombe sur un tas de site obscures qui m'explique que l'extension .EXE n'est pas associée au bon fichier.

Microsoft Learn -.NET MAUI - Publish app to a folder for Windows

C'est tout un bazar, comme d'hab ... créer un coffre avec des clefs dans l'Azure Cloud mais cela peut coûter, il vous faut choisir un mode de paiement.

Donc je créé un Certificat ...

Et puis le bazar continue ...

Déployer mon application MAUI
Déployer mon application MAUI

Error :

Impossible de vérifier le certificat d’éditeur de ce package d’application. Contactez votre administrateur système ou le développeur d’applications pour obtenir un nouveau package d’application avec des certificats vérifiés. Le certificat racine et tous les certificats immédiats de la signature dans le package d’application doivent être vérifiés (0x800B010A)

Vous souhaitez aller au bout du déploiement de votre application MAUI ?

J'ai la solution, n'hésitez pas à me contacter ;)

That's All Folks!

MAUI - Editor Keyboard ne fonctionne pas sous WinUI ?

Ce matin un lapin... ou plutôt un loup, ce loup c'est le MAUI Editor ! Je lance mon application MAUI préférée :

GitHub - Mabyre - MauiAppToolkit

Je clique dans l'Editor pour essayer de modifier le Texte en tapant quelques caractères au clavier mais cela ne fonctionne pas, seuls quelques caractères passent pas les retours chariots :

Mon MAUI Application Microsoft préférée
Mon MAUI Application Microsoft préférée

Comme la deuxième page "Console" est aussi un Editor pour la Console de messages, j'y vais, et là l'Editor fonctionne ... je peux écrire ce que je veux dedans.

Mon MAUI Application Microsoft préférée
Mon MAUI Application Microsoft préférée

Vous comprenez mon désarrois.

Je relance l'application depuis le début, je tente d'écrire dans l'Editor je ne vois pas les caractères que j'ai tapés jusqu'à ce que je rafraîchisse la page par exemple dans changeant sa taille et là je vois les caractères que j'ai tapés au clavier.

Peut-on dire que le contrôle utilisateur MAUI Editor est beugué sous Windows ?

Je reviendrais vous donner la réponse. En attendant, si le développement MAUI vous intéresse n'hésitez pas à me contacter.

Je ne sais pas bien pourquoi le Keypad "s'est bloqué" peut être un coup de InputDirector va savoir oui parce que je partage ma souris et mon clavier pour piloter 


Développement avec .NET MAUI (Multi-platform App UI) - Le graal ?

Me voici plongé dans le développement avec la technologie MAUI de Microsoft.NET et pour l'instant tout va bien ma petite application qui ouvre un fichier pour l'afficher, le modifier et le sauvegarder, va très bien, c'est très fun! Je trouve même le moyen de particulariser l'AppIcon.

GitHub - Mabyre - MauiAppToolkit

Jusqu'à ce que je déploie mon application sur mon téléphone Android. Là encore c'est très fun, le lien de débeug entre ma plateforme de Dev (Visual Studio Community 2022) et mon Cellular est parfaite je peux déboguer mon application tournant sur mon Cellular et je step le code depuis mon Visual.

Trop fort.

Mais quand je souhaite sauvegarder mon fichier, plouf ! Rien !

Alors en cherchant un peu, je trouve :

.net MAUI write to external storage - Stack Overflow

Et là je rigole bien, le pauvre, sa question n'intéresse personne et il n'y a pas de réponse à son problème parce que la réponse est trop vaste.

Une partie de la solution se trouve dans le Commit :

GitHub - try to find solution on storage problem - MauiAppToolkit@81339a5

MAUI - File - External Storage

C'est un vrai problème en effet. La difficulté, c'est que le FilePicker ne result pas le chemin réel du fichier Pické. Sur Android, il s'agit d'un chemin fictif menant au cache donc lorsque vous sauvegardez le fichier que vous avez modifié il est dans le cache !

/storage/emulated/0/Android/data/com.companyname.mauiapptoolkit/cache/2203693cc04e0be7f4f024d5f9499e13/92c9d622ed3d489a8a37b988f0c003c1/

Alors comment faire ?

Autre difficulté le FilePicker ne prend pas de Path en paramètre, il va où il veut...

Le début de la solution certainement Ici :

Microsoft Learn - FolderPicker - .NET MAUI Community Toolkit

Alors qu'avons-nous dans CommunityToolkit.Maui.Storage :

CommunityToolkit.Maui.Storage

A comparer avec Microsoft.Maui.Storage :

Microsoft.Maui.Storage

Donc pour ma part j'ai trouvé ce qu'il faut faire. Vous souhaitez en savoir, plus n'hésitez pas à me contacter les réseaux sont là pour ça.

SoDevLog - Prestations

That's All Folks!