30.9.20

WPF Avalonia Ubuntu vscode

 http://www.avaloniaui.net/

1. télécharger le zip des templates : https://github.com/AvaloniaUI/avalonia-dotnet-templates
2. sudo add-apt-repository universe
   sudo apt-get install apt-transport-https
   sudo apt-get update
   sudo apt-get install dotnet-sdk-3.1 dotnet-runtime-3.1 aspnetcore-runtime-3.1
3. dotnet new --install avalonia-dotnet-templates-master/
4. dotnet new (il doit y avoir les nouvelles options avalonia)
5. créer un répertoire pour la solution --> mkdir testAvalonia
6. cd testAvalonia
7. ouvrir ce dossier dans vscode
8. avec solution-explorer créer une nouvelle solution
9. dans le terminal aller dans le dossier testAvalonia
10. dotnet new avalonia.app -o MonApp (créé un répertoire 'MonApp' avec un projet à l'intérieur)
11. dans vscode ajoute le projet à la solution
12. builder l'application
13. dans un terminal aller dans testAvalonia/MonApp/bin/Debug/netcoreapp3.0/
14. lancer ./MonApp

23.9.20

déployer asp.net core sur ubuntu

dans visual studio :
- clic droite sur le projet
- publier
- créer un nouveau profile et publier dans un dossier
- cliquer sur publier
sur le serveur ubuntu isntaller les composants .net core :
- sudo apt-get install apt-transport-https && sudo apt-get update && sudo apt-get install dotnet-sdk-3.1 dotnet-runtime-3.1 aspnetcore-runtime-3.1
installer le serveur apache :
- sudo apt-get install apache2
- sudo a2enmod proxy proxy_http proxy_html proxy_wstunnel
- sudo a2enmod rewrite
- sudo gedit /etc/apache2/conf-enabled/netcore.conf

18.9.20

Entity Framework Core Asp.net Core MVC

 - créer un nouveau projet "Application web ASP.NET Core"

Application web (MVC)

- installer les package nuget suivants :

Microsoft.EntityFrameworkCore.SqlServer

Microsoft.EntityFrameworkCore.Tools

dans la console du gestionnaire de package nuget :

dotnet tool install --global dotnet-ef

dotnet restore

dotnet ef dbcontext scaffold "Data Source=(localdb)\MSSQLLocalDB;AttachDbFilename=C:\Users\xxx\Desktop\testSqlServer.mdf; Integrated Security=True;" Microsoft.EntityFrameworkCore.SqlServer -o Modelsxxx --project TestGenerateModels

- dans le fichier appsettings.json ajouter la ligne :

"ConnectionString": "Data Source=(localdb)\\MSSQLLocalDB;AttachDbFilename=C:\\Users\\xxx\\Desktop\\testSqlServer.mdf; Integrated Security=True;"

- dans le fichier Startup.cs

//hyper important de mettre une valeur dans la variable pour la suite

public static string ConnectionString = "bla bla bla";

- dans le fichier Startup.cs, dans méthode Configure :

Startup.ConnectionString = @Configuration.GetSection("ConnectionString").Value;

- dans le fichier de context, méthode OnConfiguring :

optionsBuilder.UseSqlServer(Startup.ConnectionString);

- dans le context ajouter la variable privée :

private string _connectionString;

- dans le context adapter le constructeur par défaut pour qu'il prenne un paramètre :

public SqlServerContext(string connectionString)

        {

            this._connectionString = connectionString;

        }

- sur le dossier "Controllers", clic droite, ajouter controlleur

Controler MVC avec EntityFramework

choisir le model

choisir le context

- dans le context ajouter un constructeur par défaut

- dans le fichier Startup.cs changer tout à la fin le nom du controller a charger par défaut pour tester

- dans le controller, commenter le constructeur qui reçoit le context en paramètre et ajouter :

public PersonnesController()

        {

            this._context = new SQLiteContext(Startup.ConnectionString);

        }


C# Task Course 100m

Quelques liens utiles :
https://www.c-sharpcorner.com/article/async-and-await-in-c-sharp/
https://docs.microsoft.com/en-us/dotnet/csharp/programming-guide/concepts/async/
-----------------------------------------------------------------------------------------------------
public class Course100M
{
public static bool isGagnant = false;
public static int vainqueur = 0;
public static int nombreParticipants = 5;
static async Task Main(string[] args)
{
Course100M.isGagnant = false;
Console.WriteLine("A vos marques...");
Thread.Sleep(1000);
Console.WriteLine("Prêts...");
Thread.Sleep(1000);
Console.WriteLine("Partez!!!");
int vainqueurx = await DepartDeLaCourse();
Console.WriteLine($"{vainqueurx}");
Console.WriteLine("-->Course terminée<--");
Console.ReadKey();
}
public static async Task<int> DepartDeLaCourse()
{
await Task.Run(() =>
{
for (int i = 1; i <= Course100M.nombreParticipants; i++)
{
_ = Coureur(i);
}
});
while (Course100M.vainqueur == 0)
{
Thread.Sleep(1000);
Console.WriteLine("Quel suspens...");
}
return Course100M.vainqueur;
}
public static async Task/*<int>*/ Coureur(int numCoureur)
{
CancellationTokenSource source = new CancellationTokenSource();
CancellationToken token;
await Task.Run(() =>
{
//100 mètres
for (int i = 1; i <= 10; i++)
{
Thread.Sleep(500 - numCoureur);
//Console.WriteLine($"{numCoureur}. {i * 10} mètres");
string x = "";
for (int y = 1; y <= i; y++)
{
x = x + " --> ";
}
if (i * 10 != 100)
{
Console.WriteLine($"{numCoureur}. {x}");
} else
{
Console.WriteLine($"{numCoureur}. Terminé!!!");
if (Course100M.isGagnant == false)
{
Course100M.isGagnant = true;
Console.WriteLine("------------------------");
Console.WriteLine($"VAINQUEUR : {numCoureur}");
Console.WriteLine("------------------------");
Course100M.vainqueur = numCoureur;
source.Cancel();
}
}
}
}, token);
}
}

10.9.20

Désactiver l'assistant Google sur Android

- allez dans l'application Google de votre téléphone

- appuyer sur "plus" en bas à droite

- "paramètres"

- "assistant google"

- onglet "assistant"

- cherchez "téléphone" en bas 

- désactivez "assistant google"