Gestion des contacts Surface sous XNA 3.1

Aujourd'hui je vous propose une petite librairie pour Surface que j'ai développé. Elle vous permet d'ajouter la gestion des contacts surface dans une application XNA 3.1. Pour télécharger cette librairie c'est par là : XnaTouchManager.rar (7,68 kb).

Cette librairie se compose en deux classes :

XnaTouchManager :

Classe statique qui implémente la gestion des contacts. Pour pouvoir utiliser la classe, il faut apporter deux modifications dans votre application root Surface XNA.

private void InitializeSurfaceInput()
{
  // ...
  // Placer la ligne a la fin de la fonction 

  XnaTouchManager._ContactTarget = contactTarget;
}

protected override void Update(GameTime gameTime)
{
  if (this.m_bIsApplicationActivated || this.m_bIsApplicationPreviewed)
  {
    if (this.m_bIsApplicationActivated)
    {
      XnaTouchManager.Update((float)gameTime.ElapsedGameTime.TotalMilliseconds);
    }

    // ...
    // Reste de la fonction ici
  }
}

Ensuite pour accéder aux fonctions de ce manager il existe des fonctions statiques :

- XnaTouchContact GetContact(int p_iD)
  Cette fonction récupère un contact par son identifiant, elle renvoie NULL si elle ne l'a pas trouvé.

- bool TryGetContact(int p_iD, out XnaTouchContact p_oContact)
  Cette fonction test si un contact existe, si il existe elle renvoie l'instance du contact en paramètre out, le retour de la fonction détermine si le contact a été trouvé.

Et des variables statiques rafraichis a chaque Update :

- _ContactsNew : Liste des nouveaux contacts, cela veux dire qu'ils n'étaient pas présents au dernier Update.

- _ContactsUpdate : Liste des contacts encore présent, cela veux dire qu'ils étaient présents au dernier Update

- _ContactsOld : Liste des anciens contacts, cela veux dire qu'ils étaient présents au dernier Update et que maintenant il n'existe plus.

Cela vous permet donc de gérer facilement la mise à jour de vos conctacts.

Il reste une dernière classe : XnaTouchContact

Elle permet quand vous utilisez les fonctions  GetContact et TryGetContact de vous fournir le contact rechercher et d'où il provient (liste des nouveaux contacts, des mises à jours ou des anciens).

J'espère que cela vous sera utile, je suis aussi preneur de vos retours.


Tags: , ,
Catégories: Surface | XNA

0 Commentaires
Actions: Permalink | Comment RSSRSS comment feed

Appliquer un Shader sur le rendu final

Article pour un rendu en 2D avec XNA 3.0 

Quand on développe des jeux avec XNA, on voudrais parfois appliquer un Shader sur le rendu final de la scène, à savoir l'image qui est produite après le rendu de chaque objet de notre jeu. Appliquer un Shader sur un objet est chose facile, mais sur le rendu final de la scène en est une autre.

La première question que l'on se pose : Comment récupérer le rendu final sous forme de texture 2D. Pour cela il faut savoir qu'il est possible de détourner le rendu effectué par le SpriteBatch vers une autre source de rendu que le buffer d'affichage. Pour ce la il suffit d'utiliser la fonction SetRenderTarget() sur l'objet GraphicDevice. Cette fonction permet de changer l'endroit ou le rendu est fait.

Une fois cette fonction invoquée, vous pouvez dessiner avec le SpriteBatch et pour récupérer le résultat il suffit d'appeller ResolveBackBuffer() sur l'objet GraphicDevice. Vous allez alors récupérer une Texture2D sur laquelle vous pourrez appliquer le Shader final. Il faudra par contre ne pas oublier de changer le buffer de rendu pour revenir vers le buffer d'affichage.

RenderTarget2D renderTarget;
SpriteBatch spriteBatch;

// Création du SpriteBatch

spriteBatch = new SpriteBatch(this.GraphicsDevice);

// On change le buffer d'écriture pour rendre
// la scéne dans une Texture2D de type RenderTarget2D

this.GraphicsDevice.SetRenderTarget(0, renderTarget);
this.GraphicsDevice.Clear(Color.TransparentWhite);

// On dessine notre scène

spriteBatch.Begin();

// ...

spriteBatch.End();

// On remet le buffer d'écriture sur l'écran

this.GraphicsDevice.SetRenderTarget(0, null);

// On charge notre Shader

Effect effect = this.Content.Load<Effect>("MonShader");

// Démarage de l'affichage, on commence par le BEGIN du spriteBatch
// puis par celui du Shader pour préparer le Device au rendu

spriteBatch.Begin();
effect.Begin();

// On effectue les passes du Shader (en prenant la texture du render target)

foreach ( EffectPass oPass in effect.CurrentTechnique.Passes )
{
    oPass.Begin();
    spriteBatch.Draw(renderTarget.GetTexture(), new Vector2(0.0f, 0.0f), Color.White);
    oPass.End();
}

// Fin du rendu du Shader

effect.End();
spriteBatch.End();


Tags: , ,
Catégories: XNA

0 Commentaires
Actions: Permalink | Comment RSSRSS comment feed

XNA Game Studio 3.0 CTP

Bonjour,

L'équipe XNA vient de rendre disponible une version "Community Technical Preview" de la version 3.0 de ce framework. Dans les changements apportés par cette version on trouve notamment :

  • Le support du framework 3.5.
  • L'intégration d'XNA dans Visual Studio 2008 (et seulement VS2008)
  • Le support du developpement de jeux sur Zune.
  • Le content pipeline pourra accepter directement les fichiers son (wav, wma, mp3)
  • Support pour Direct3D des Shaders Matériel grâce aux fichiers .fbx

La release finale devrait sortir normalement courant de l'été 2008. Vous pouvez trouver la CTP ici.


Tags: ,
Catégories: C# | XNA

0 Commentaires
Actions: Permalink | Comment RSSRSS comment feed