|
Trouver une ressource
Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !
ROTATION D'IMAGE POUR LE COMPACT FRAMEWORK
Information sur la source
Description
Bonjour à tous et à toutes! ceci est juste une petite fonction en C# pour palier à l'absence de méthode de rotation d'image dans le Compact Framework,... dans un premier temps on va calculer la taille de l'image après rotation puis on applique un couleur d'arrière plan à la nouvelle image (ici on prendra arbitrairement la couleur du pixel (0,0) de l'image d'origine pour couleur d'arrière plan, et enfin on va chercher pour chacun des pixels de l'image finale le pixel correspondant dans l'image d'origine...
Source
- public static System.Drawing.Bitmap Rotate(System.Drawing.Bitmap ImageSource, int angle)
- {
- //Déclaration des variables utiles à la rotation
- System.Drawing.Bitmap RotatedImage;
- int i;
- int j;
- System.Drawing.Color couleur;
- int mx, my, mxdest, mydest;
- int bx, by;
- double angle_radian;
- double tcos;
- double tsin;
- double largeurdest;
- double hauteurdest;
-
- //calcul de l'angle en radian, ainsi que du cosinus et sinus de l'angle qui seront utiliser régulièrement
- angle_radian = -angle * Math.PI / 180.0;
- tcos = Math.Cos(angle_radian);
- tsin = Math.Sin(angle_radian);
-
- //calcul de la taille maximal de l'image après rotation (pour éviter de perdre des "morceaux d'image"
- largeurdest = Math.Ceiling(ImageSource.Width * Math.Abs(tcos) + ImageSource.Height * Math.Abs(tsin));
- hauteurdest = Math.Ceiling(ImageSource.Width * Math.Abs(tsin) + ImageSource.Height * Math.Abs(tcos));
-
- //Instanciation de l'image finale avec la taille calculer
- RotatedImage = new System.Drawing.Bitmap((int)Math.Ceiling(largeurdest), (int)Math.Ceiling(hauteurdest));
-
- //Calcul du centre de l'image source et de l'image après rotation (pour recentrer l'image)
- mxdest = RotatedImage.Width / 2;
- mydest = RotatedImage.Height / 2;
- mx = ImageSource.Width / 2;
- my = ImageSource.Height / 2;
-
- //On applique comme couleur d'arrière plan de notre nouvelle image la couleur du premier pixel de l'image d'origine (arbitraire)
- for (j = 0; j < RotatedImage.Height; j++)
- {
- for (i = 0; i < RotatedImage.Width; i++)
- {
- RotatedImage.SetPixel(i, j, ImageSource.GetPixel(0, 0));
- }
- }
-
- //rotation de l'image
- for (j = 0; j < RotatedImage.Height; j++)
- {
- for (i = 0; i < RotatedImage.Width; i++)
- {
- //On recherche les coordonnées du pixel i,j de la nouvelle image dans l'image source
- bx = (int)(Math.Ceiling(tcos * (i - mxdest) + tsin * (j - mydest) + mx));
- by = (int)(Math.Ceiling(-tsin * (i - mxdest) + tcos * (j - mydest) + my));
- if (bx >= 0 && bx < ImageSource.Width && by >= 0 && by < ImageSource.Height)
- {
- //On récupère la couleur du pixel bx,by de l'image source
- couleur = ImageSource.GetPixel(bx, by);
-
- //On recopie la couleur trouver dans le pixel correspondant
- RotatedImage.SetPixel(i, j, couleur);
- }
- }
- }
- return RotatedImage;
- }
public static System.Drawing.Bitmap Rotate(System.Drawing.Bitmap ImageSource, int angle)
{
//Déclaration des variables utiles à la rotation
System.Drawing.Bitmap RotatedImage;
int i;
int j;
System.Drawing.Color couleur;
int mx, my, mxdest, mydest;
int bx, by;
double angle_radian;
double tcos;
double tsin;
double largeurdest;
double hauteurdest;
//calcul de l'angle en radian, ainsi que du cosinus et sinus de l'angle qui seront utiliser régulièrement
angle_radian = -angle * Math.PI / 180.0;
tcos = Math.Cos(angle_radian);
tsin = Math.Sin(angle_radian);
//calcul de la taille maximal de l'image après rotation (pour éviter de perdre des "morceaux d'image"
largeurdest = Math.Ceiling(ImageSource.Width * Math.Abs(tcos) + ImageSource.Height * Math.Abs(tsin));
hauteurdest = Math.Ceiling(ImageSource.Width * Math.Abs(tsin) + ImageSource.Height * Math.Abs(tcos));
//Instanciation de l'image finale avec la taille calculer
RotatedImage = new System.Drawing.Bitmap((int)Math.Ceiling(largeurdest), (int)Math.Ceiling(hauteurdest));
//Calcul du centre de l'image source et de l'image après rotation (pour recentrer l'image)
mxdest = RotatedImage.Width / 2;
mydest = RotatedImage.Height / 2;
mx = ImageSource.Width / 2;
my = ImageSource.Height / 2;
//On applique comme couleur d'arrière plan de notre nouvelle image la couleur du premier pixel de l'image d'origine (arbitraire)
for (j = 0; j < RotatedImage.Height; j++)
{
for (i = 0; i < RotatedImage.Width; i++)
{
RotatedImage.SetPixel(i, j, ImageSource.GetPixel(0, 0));
}
}
//rotation de l'image
for (j = 0; j < RotatedImage.Height; j++)
{
for (i = 0; i < RotatedImage.Width; i++)
{
//On recherche les coordonnées du pixel i,j de la nouvelle image dans l'image source
bx = (int)(Math.Ceiling(tcos * (i - mxdest) + tsin * (j - mydest) + mx));
by = (int)(Math.Ceiling(-tsin * (i - mxdest) + tcos * (j - mydest) + my));
if (bx >= 0 && bx < ImageSource.Width && by >= 0 && by < ImageSource.Height)
{
//On récupère la couleur du pixel bx,by de l'image source
couleur = ImageSource.GetPixel(bx, by);
//On recopie la couleur trouver dans le pixel correspondant
RotatedImage.SetPixel(i, j, couleur);
}
}
}
return RotatedImage;
}
Conclusion
Ce code source est optimisable je pense mais en tout cas il est fonctionnel, n'ésitez pas à me signaler les éventuelles difficultés pour faire fonctionner ce code... Attention ce code n'a pas pour prétention de faire mieux que les méthode éxistantes dans le Framework 2.0 complet mais juste de pallier à l'absence de ces méthodes dans le CompactFramework...
Historique
- 08 août 2007 16:23:15 :
- Déplacement de la source sur http://www.pdafr.com/
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
RSS XML PPC [ par manu00 ]
Bonjour, je dois developper un lecteur de flux rss sur pocket pc mais je ne sais pas par ou commencer... Que me conseillez vous ? Visual Basic .net ou
vb.net Lancer un executable sur ppc [ par garocheb ]
Bonjour, Je suis un nouveau en vb.net et je n'arrive pas a trouver comment on peux lancer un executable se trouvant dans "\my documents\12.exe" Aidez
Recevoir infrarouge sur Smartphone ou PPC [ par azerty25 ]
BonjourJe voudrais faire un programme, de préférence en .NET, qui m'affiche les codes que le matériel reçoi par le port IR.Dans le
[.NET2 CF]IrCOMM et IrDA [ par NHenry ]
Bonjour,J'utilise un PPC, j'ai constaté que pour mes essais, j'ai 3 PPC pour mes tests, un seul a le port IrCOMM en COM2, les autres je ne sais pas.J'
VB.Net Démarer l'exécutable sans être sur un PDA [ par JeffC1977 ]
Salut à tous....Est-il possible de faire fonctionner correctement mon programme (l'exécutable) sur un PC sans utiliser le simulateur...Je démarre le p
VB.Net Créer l'exécutable ??? [ par JeffC1977 ]
Salut à tous....Pour une raison que j'ignore, je ne suis plus capable de créer un exécutable...Je vais dans le memu Build et je fais Build Projet_Clac
Pb avec eVC++ [ par artefakt60 ]
Je suis développeur DotNet (essentiellement C# pour des applis Windows Forms ou des sites Asp.Net), et je dois maintenant me mettre à développer une (
Pocket PC connexion wifi [ par wassimez ]
Salut j'ai commencer depuis un peut de programmer sur pocket pc, j'ai un projet qui nécessite de faire une connexion réseau wifi entre le PPC et le
Synchronisation de données avec vista [ par necrom ]
Voila tous le monde en parle mais les réponses ne font pas rages ou ne sont pas précise. Je developpe actuellement en vb.net 05 une application capabl
|
Téléchargements
Logiciels à télécharger sur le même thème :
|