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
30.9.20
WPF Avalonia Ubuntu vscode
23.9.20
déployer asp.net core sur ubuntu
- 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
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"