Dans un article précédent j’avais expliqué comment changer la couleur d’une image PNG avec du code C++. Dans celui-ci je voulais montrer mon design spaghetti pour le faire dans Unreal Engine.
Mon but premier est de pouvoir changer la couleur de peau de mes personnages le plus facilement possible. J’ai donc décidé d’avoir un matériel avec un paramètre qui me permettrait de sélectionner la couleur désirée. Pour permettre cela, j’ai modifié la texture originale pour mettre du magenta (FF00FF) où il y aura la couleur à modifier. Voici une capture d’écran du résultat dans Unreal Engine:
On peut observer dans le milieu en bas complètement qu’il y a un paramètre qui permet de choisir la couleur désirée. Ce n’est pas obligatoire mais j’ai gardé la possibilité d’utiliser la texture originale avec un paramètre nommé Enable.
En général, ce que je voulais montrer, c’est la complexité d’utiliser un langage de script visuel. Peut-être que c’est juste à cause de mon expérience dans d’autre langage de programmation, mais la façon d’extraire les composants RGB d’une image nécessite un paquet de boite et de connexion.
Le plus important c’est le résultat final, alors le voici.
Dans un article précédent j’avais listé les émotes disponibles dans le jeu Valheim. Depuis la version qui inclut le biome du Mistlands, il y a maintenant encore plus de choix.
Tout le monde en parle, donc pourquoi ne pas le faire aussi. L’intelligence artificielle, IA, est de plus en plus utilisée pour accomplir diverses tâches. DALL-E est une IA qui permet de générer des images à partir de texte en langage naturel. J’utilise le pseudo Crayon et j’ai décidé de voir si l’IA serait capable de me créer un avatar. Voici un premier exemple avec le texte qui a servi à la génération dans la légende.
Ces temps-ci je joue pas mal au jeu vidéo Red Dead Online, j’ai donc demandé à l’AI de générer un look cowboy à l’avatar.
Je trouvais qu’il manquait quelque chose… ah oui! L’arrière plan.
DALL-E a beaucoup de difficulté avec les mains. En plus, elle n’est pas capable de générer correctement du texte. En général, si on lui donne les bonnes entrées, on peut vraiment être surpris du résultat. Je trouve ça incroyable que ces images n’existent nulle part et on été entièrement générées par une IA qui comprend ce que je lui dis.
Le jeu Valheim permet l’utilisation d’émotes (émotions animées). Par contre, je considère qu’elles ne sont pas faciles à utiliser rapidement. Par exemple, pour envoyer la main à un autre joueur, il faut ouvrir la console de chat et inscrire la commande /wave. Heureusement, le jeu nous permet de lier certaines actions à une touche du clavier.
Premièrement, voici la liste des émotes présentement disponibles dans le jeu.
Commande
Description
/wave
Envoyer la main
/thumbsup
Montrer les pouces vers le haut
/point
Pointer dans une direction
/nonono
Agiter les mains pour signifier non
/cheer
Célébrer en levant le poing en l’air
/challenge
Lancer un défi
/sit
S’asseoir
À l’exception du dernier émote qui est déjà disponible en appuyant sur la touche x, on veut que les autres le soient aussi rapidement. La commande /bind permet de lier une action à une touche de clavier. Étant donné que Valheim utilise l’engin de jeu Unity, les codes de clés sont disponibles sur cette page. Dans mon cas, je veux les lier aux touches du clavier numérique. Alors, voici les commandes à entrer.
Pour voir la liste des commandes liées, vous pouvez utiliser la commande /printbinds. Pour délier une action, la commande est /unbind suivi du code de clé. Finalement, pour tout annuler, il existe la commande /resetbinds.
Il y a un an jour pour jour, j’écrivais un article à propos de Piskel, un éditeur en ligne gratuit pour créer des sprites animés et du pixel art. Si vous avez un compte sur le site, il est important de mentionner qu’à partir d’aujourd’hui il sera supprimé. Cela n’empêche pas d’utiliser l’application et d’enregistrer localement vos animations.
Sans plus tarder, voici la nouvelle création de mon fils qu’il vient de terminer :
En regardant sur mon disque dur, j’ai retrouvé quelques animations que j’avais oublié de montrer dans mon dernier article. Alors voici d’autre créations de mon fils :
En terminant, je vous rappelle que le code source est disponible sur GitHub et que l’application peut être utilisée à partir de cet URL : https://www.piskelapp.com
Dans cet article, j’expliquerai comment utiliser NSSM pour démarrer Valheim Dedicated Server en tant que service. Dernièrement, j’ai eu la piqûre pour le jeu d’exploration et de survie Valheim. Je voulais que mon monde soit hébergé sur mon serveur Windows et que mes amis puissent y accéder facilement. Heureusement, les outils mis à notre disposition sont relativement faciles à utiliser.
La première étape est d’installer le serveur. Je ne voulais pas devoir installer Steam sur mon serveur et je ne voulais pas devoir y lier mon profil. La bonne nouvelle est que SteamCMD existe pour pallier à ce problème. Il suffit de télécharger le fichier zip pour Windows et de l’extraire. Une fois disponible, il faut exécuter l’application steamcmd.exe. Une fenêtre de commande devrait être disponible. Voici les commandes à écrire:
login anonymous
app_update 896660
quit
Ces commandes servent à installer ou mettre à jour Valheim Dedicated Server. Une fois l’installation terminée, dans votre dossier SteamCMD il devrait y avoir un nouveau dossier nommé \steamapps\common\Valheim dedicated server. Ce dossier est important pour la prochaine étape.
La deuxième étape est de démarrer le serveur. La plupart des tutoriels vont dire de créer une copie du fichier start_headless_server.bat pour y inscrire vos informations, mais dans notre cas nous allons seulement nous en inspirer pour démarrer le service avec NSSM. NSSM signifie Non-Sucking Service Manager et, comme son nom l’indique, est un gestionnaire de service « performant ». L’application possède une interface graphique pour installer, éditer ou supprimer un service créé à partir de NSSM. Par contre, dans cet article, c’est plutôt des lignes de commande que nous utiliserons. Alors sans plus tarder, voici ces commandes (qui devront être modifiées pour accommoder vos préférences):
set valheimpath=C:\SteamCmd\steamapps\common\Valheim dedicated server
nssm install valheim "%valheimpath%\valheim_server"
nssm set valheim AppDirectory "%valheimpath%"
nssm set valheim AppParameters "-nographics -batchmode -name \"Nom du Serveur\" -port 2456 -world \"Monde\" -password \"MotDePasse\" -savedir \"C:\Valheim\" -public 1"
nssm set valheim DisplayName "Valheim Dedicated Server"
nssm set valheim Description "A server for the Valheim game."
nssm set valheim Start SERVICE_DELAYED_AUTO_START
nssm set valheim AppStdout "%valheimpath%\logs\nssm.log"
nssm set valheim AppStderr "%valheimpath%\logs\nssm.log"
nssm set valheim AppRotateFiles 1
nssm set valheim AppRotateBytes 1000000
nssm set valheim AppEnvironmentExtra SteamAppId=892970
nssm start valheim
La première ligne doit être modifiée pour y mettre le chemin où se trouve l’exécutable valheim_server.exe. La ligne 4 est sans doute la plus importante. Elle permet de spécifier le nom du serveur, le nom du monde, le mot de passe pour accéder au serveur et le dossier où enregistrer les sauvegardes. Pour plus d’information sur ces paramètres, il y a un manuel sous format PDF dans le dossier de l’exécutable. La dernière ligne est celle qui démarre le serveur dédié.
Si vous désirez supprimer le service, c’est cette commande qu’il faut utiliser:
nssm remove valheim
Pour éditer un service déjà installé avec l’interface, on utilise cette commande:
nssm edit valheim
La troisième étape consiste à configurer votre pare-feu pour ouvrir les bons ports. Il faut démarrer Windows Firewall With Advanced Security. En premier, dans la section Inbound Rules, on clique sur New Rule pour y ajouter une règle pour TCP avec les ports 2456-2458. On fait la même chose pour UDP avec les ports 2456-2458. En second lieu, dans la section Outbound Rules, on clique sur New Rule pour y ajouter une règle pour TCP avec les ports 2456-2458. Finalement, on fait la même chose pour UDP avec les ports 2456-2458. La configuration du serveur devrait être terminé.
La quatrième étape est d’ajouter le serveur dans Steam sur votre PC. Il faut simplement aller dans le menu View et par la suite on choisit Servers. Vous cliquez sur le bouton ADD A SERVER et vous suivez les étapes. Pour démarrer une partie, il va falloir utiliser ce nouveau serveur. Le mot de passe utilisé plus haut va vous être demandé avant d’ouvrir le jeu et une seconde fois dans le jeu lorsque vous démarrez la partie.
Voilà, c’est terminé! Vous devriez maintenant être en mesure de jouer avec vos amis dans le même monde.
Dans mon dernier article, j’avais parlé de MagicaCSG, un logiciel dont ma fille avait maitrisé les bases assez rapidement. Cette fois-ci, ce sera le tour de MagicaVoxel, un autre logiciel gratuit de ephtracy. Il est disponible pour macOS et Windows et permet de concevoir assez facilement des modèles 3D en voxel. L’idée est simple: on utilise des cubes de couleur pour bâtir un objet 3D complexe.
Mon garçon de 13 ans qui s’initie à la conception de jeux vidéo a poussé l’exercice plus loin que de bonnement faire un mesh texturé dans MagicaVoxel. Il voulait l’animer et l’importer dans l’engin de jeu Unreal. Pour faire l’ossature et l’animation, il s’est servi de Mixamo. Pour y utiliser son modèle 3D, il l’a d’abord exporté en format obj à partir de MagicaVoxel. Ceci va générer trois fichiers (.obj, .mtl et .png) qui devront être compressés en un seul fichier de format zip. C’est ce fichier qui sera importé dans Mixamo. Une fois les différents points sélectionnés sur le modèle pour définir le squelette, il faudra simplement choisir une animation et la télécharger.
Le fichier fbx téléchargé devra être importé dans Unreal Engine. Si tout fonctionne bien, ceci devrait créer le squelette, le mesh, la texture, le matériel, l’animation et les autres items nécessaires à l’engin de jeu.
Je vous laisse avec un gif du personnage animé dans Unreal Engine. Considérant qu’il s’agit du premier modèle 3D animé entièrement conçu par mon fils, je trouve le résultat assez bien réussi.
Il y a quelques mois, un nouveau logiciel d’édition 3D gratuit faisait son apparition. Il s’agit de MagicaCSG. Il est développé par ephtracy. Présentement, il est seulement disponible pour Windows. Ce logiciel est simple d’utilisation. Ma fille de 10 ans a créé ces modèles sans rien connaitre de la 3D en moins de deux heures.
Dans la version actuelle, il est seulement possible d’exporter le mesh dans le format ply (Polygon File Format). Cela vous permettra de l’ouvrir dans Blender si vous avez du traitement supplémentaire à y faire.
Subversion ne gère pas les étiquettes de la même manière que Git. C’est pour cette raison que suite à une importation je me retrouve souvent à devoir faire des modifications à mon historique. Une étiquette créée lors d’une importation est composée d’une soumission sur laquelle une étiquette légère est ajoutée. Ce que je veux, c’est une étiquette annotée sans l’ajout d’une soumission inutile. Dans cet article, nous allons voir comment faire cela. Il est important de mentionner que les lignes de commandes mentionnées plus bas ont un impact sur votre historique. Faites attention de bien les comprendre avant de les utiliser.
Utilisez cette commande pour voir quelles étiquettes doivent être changées:
S’il n’y a pas de date à coté de la version, c’est que l’étiquette doit être modifiée. Par exemple, ici les versions 3.2.x à 3.4.x doivent être modifiées:
Dans l’image suivante on peut confirmer que c’est effectivement la vérité. Les dates affichées sont celles des étiquettes annotées uniquement, ce qui n’est pas le cas pour l’étiquette légère v3.4.0.
La nouvelle étiquette doit conserver la date de la soumission 72dce852, car c’est à cette date que la relâche a normalement eu lieu. Dans l’image précédente on peut voir que la dernière soumission pour la relâche a été effectuée au mois de mai. Par contre, l’étiquette a été créée au mois de juin. Utilisez la commande suivante pour récupérer la bonne date:
Cette commande donne la date de la dernière soumission effectuée avant l’étiquette et non la date de l’étiquette. C’est pourquoi cette commande nous sert pour les étiquettes non conformes. Maintenant, pour créer la nouvelle étiquette, on fait une commande similaire à celle-ci:
GIT_COMMITTER_DATE="2016-06-23 15:35:04 -0400" \
git tag --annotate v3.4.0 \
--message="Tag the 3.4.0 release" \
d4ac586497b0642152fde2c682984bfbfe453113
À la première ligne, vous devez mettre la date de l’étiquette. La deuxième ligne sert à spécifier le nom de l’étiquette annotée. La troisième ligne est le message de l’étiquette. Finalement, la quatrième sert à désigner la dernière soumission sur laquelle l’étiquette est attachée. Lorsque que la commande est exécutée, il est possible d’avoir une erreur si vous tentez de créer une étiquette qui existe déjà. Alors, il suffit de supprimer l’étiquette existante et de réessayer la commande.
Comme on peut le voir dans l’image précédente, la soumission inutile a été supprimée et une étiquette annotée a été créée à la date de l’ancienne étiquette. Donc l’historique est complètement conservé.
Si une étiquette du même nom existe sur le serveur, vous devez d’abord la supprimer avec cette commande et ensuite vous pourrez pousser la nouvelle:
git push --delete origin v3.4.0
Il suffit maintenant de répéter ces étapes pour chaque étiquettes. J’espère pour vous qu’elles ne sont pas trop nombreuses. Sinon, il y a toujours moyen de vous simplifier la vie en générant toutes vos commandes avec une commande de la sorte:
Dans cet article, j’expliquerai comment utiliser NSSM pour démarrer un agent Jenkins sur Windows en tant que service. Jenkins est un outil d’intégration continue que j’utilise pour gérer mes projets sous git. L’application programmée en Java possède une interface web très intuitive. Un autre de ses avantages est que l’on peut distribuer la charge de la construction et du déploiement d’une application sur plusieurs agents.
Pour un agent Linux, j’utilise habituellement comme Launch method l’option Launch agents via SSH. Pour un agent Windows, c’est plutôt l’option Launch agent by connecting it to the master qui sera utilisée. Une fois l’agent configuré, nous serons confrontés à une page similaire à l’image suivante.
La première option permet de télécharger une application JNLP (Java Network Launch Protocol) qui démarrera l’agent. Il est aussi possible de l’installer en tant que service. Par contre, mon anti-virus m’empêche de l’ouvrir et/ou de l’installer. C’est l’une des raisons qui m’a poussé à utiliser l’application NSSM. NSSM signifie Non-Sucking Service Manager et, comme son nom l’indique, est un gestionnaire de service « performant ». L’application possède une interface graphique pour installer, éditer ou supprimer un service créé à partir de NSSM. Par contre, dans cet article, c’est plutôt des lignes de commande que nous utiliserons.
Premièrement, pour me simplifier la tâche, j’ai installé nssm.exe dans le dossier C:\jenkins. C’est le Remote root directory dans lequel l’agent va opérer. Ensuite, on ouvre une fenêtre de terminal et on tape toutes ces commandes:
nssm install jenkinsagent "C:\jenkins\java\bin\java.exe"
nssm set jenkinsagent AppDirectory "C:\jenkins"
nssm set jenkinsagent AppParameters "-jar agent.jar -jnlpUrl http://server.com/ci/computer/Demo/jenkins-agent.jnlp -secret ba206ed36a928e773024ea46afdbfb8e33abd0de67f93c73213c4dcf229a1990 -workDir \"c:\jenkins\""
nssm set jenkinsagent DisplayName "Jenkins Agent Service"
nssm set jenkinsagent Description "A Jenkins agent."
nssm set jenkinsagent Start SERVICE_DELAYED_AUTO_START
nssm set jenkinsagent AppStdout "C:\jenkins\logs\nssm.log"
nssm set jenkinsagent AppStderr "C:\jenkins\logs\nssm.log"
nssm set jenkinsagent AppRotateFiles 1
nssm set jenkinsagent AppRotateBytes 1000000
nssm start jenkinsagent
L’agent nécessite d’être démarré par Java.exe, donc la ligne 1 doit être le chemin vers ce fichier. La ligne 3 est une copie de ce que vous allez trouver sur la page web de l’agent. La dernière ligne va démarrer le service. Après cette étape, l’agent devrait maintenant être disponible dans Jenkins.
Si vous désirez supprimer le service, c’est cette commande qu’il faut utiliser:
nssm remove jenkinsagent
Pour éditer un service déjà installé avec l’interface, on utilise cette commande: