begin process at 2012 05 28 12:41:21
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Graphique

 > CADRE OU RECTANGLE DE SÉLECTION ( UN PEU COMME SOUS LE BUREAU WINDOWS )

CADRE OU RECTANGLE DE SÉLECTION ( UN PEU COMME SOUS LE BUREAU WINDOWS )


 Information sur la source

Note :
10 / 10 - par 1 personne
10,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Graphique Niveau :Débutant Date de création :20/05/2005 Date de mise à jour :20/05/2005 16:51:54 Vu :6 021

Auteur : Moussetique

Ecrire un message privé
Site perso
Commentaire sur cette source (7)
Ajouter un commentaire et/ou une note

 Description

Cliquez pour voir la capture en taille normale
Salut

Alors ce code pour l'instant ce comporte comme le cadre de sélection d'icones de Windows. C'est à dire un déplacement de la souris avec le boutton gauche appuyé.

Source

  • <html>
  • <head>
  • <title>cadre de sélection</title>
  • <style type="text/css">
  • <!--
  • body {
  • margin-left: 0px;
  • margin-top: 0px;
  • margin-right: 0px;
  • margin-bottom: 0px;
  • width:100%;
  • height:100%;
  • }
  • .rectangle {
  • position:absolute;
  • left:0px;
  • top:0px;
  • width:100px;
  • height:100px;
  • z-index:5;
  • visibility: hidden;
  • font-size: 0px;
  • border: 1px dashed;
  • }
  • .masque {
  • position:absolute;
  • left:0px;
  • top:0px;
  • width:100%;
  • height:100%;
  • z-index:4;
  • }
  • .textbox {
  • font-family: Verdana, Arial, Helvetica, sans-serif;
  • font-size: 9px;
  • font-style: italic;
  • }
  • -->
  • </style>
  • <script language="javascript">
  • var hauteur=300;
  • var largeur=600;
  • var nbr_colonnes=9;
  • var nbr_lignes=5;
  • var couleur_ON="#CCFFFF";
  • var couleur_OFF="#FFFFCC";
  • var x_init=0;
  • var y_init=0;
  • var largeur_rect=0;
  • var hauteur_rect=0;
  • var etat_rect = false;
  • var coin_hg = new Array(0,0); // haut gauche
  • var coin_hd = new Array(0,0); // haut droite
  • var coin_bg = new Array(0,0); // bas gauche
  • var coin_bd = new Array(0,0); // bas droite
  • function coordonnées_select()
  • {
  • var i=0;
  • var j=0;
  • var cpt_col=0;
  • var cpt_lig = 0;
  • var str;
  • //gestion des coordonnées X
  • if (event.clientX >= x_init)
  • {
  • coin_hg[0] = Math.floor(x_init/(largeur/nbr_colonnes));
  • coin_hd[0] = Math.floor((x_init+largeur_rect)/(largeur/nbr_colonnes));
  • coin_bg[0] = Math.floor(x_init/(largeur/nbr_colonnes));
  • coin_bd[0] = Math.floor((x_init+largeur_rect)/(largeur/nbr_colonnes));
  • }
  • else
  • {
  • coin_hg[0] = Math.floor((x_init-largeur_rect)/(largeur/nbr_colonnes));
  • coin_hd[0] = Math.floor(x_init/(largeur/nbr_colonnes));
  • coin_bg[0] = Math.floor((x_init-largeur_rect)/(largeur/nbr_colonnes));
  • coin_bd[0] = Math.floor(x_init/(largeur/nbr_colonnes));
  • }
  • //gestion des coordonnées Y
  • if (event.clientY >= y_init)
  • {
  • coin_hg[1] = Math.floor(y_init/(hauteur/nbr_lignes));
  • coin_hd[1] = Math.floor(y_init/(hauteur/nbr_lignes));
  • coin_bg[1] = Math.floor((y_init+hauteur_rect)/(hauteur/nbr_lignes));
  • coin_bd[1] = Math.floor((y_init+hauteur_rect)/(hauteur/nbr_lignes));
  • }
  • else
  • {
  • coin_hg[1] = Math.floor((y_init-hauteur_rect)/(hauteur/nbr_lignes));
  • coin_hd[1] = Math.floor((y_init-hauteur_rect)/(hauteur/nbr_lignes));
  • coin_bg[1] = Math.floor(y_init/(hauteur/nbr_lignes));
  • coin_bd[1] = Math.floor(y_init/(hauteur/nbr_lignes));
  • }
  • slct();
  • document.getElementById("case1_hg").value = coin_hg[0];
  • document.getElementById("case1_hd").value = coin_hd[0];
  • document.getElementById("case1_bg").value = coin_bg[0];
  • document.getElementById("case1_bd").value = coin_bd[0];
  • document.getElementById("case2_hg").value = coin_hg[1];
  • document.getElementById("case2_hd").value = coin_hd[1];
  • document.getElementById("case2_bg").value = coin_bg[1];
  • document.getElementById("case2_bd").value = coin_bd[1];
  • }
  • function init_souris_rectangle_up()
  • {
  • document.getElementById("rectangle").style.visibility="hidden";
  • etat_rect=false;
  • unslct()
  • }
  • function init_souris_rectangle_down()
  • {
  • x_init=event.clientX;
  • y_init=event.clientY;
  • //initialisation du rectangle sans attendre le 1er mouvement de souris
  • souris_rectangle_move();
  • etat_rect=true;
  • document.getElementById("rectangle").style.visibility="visible";
  • }
  • function souris_rectangle_move()
  • {
  • //affichage des coordonnées
  • document.getElementById("coordonnéeX").value=event.clientX + " x";
  • document.getElementById("coordonnéeY").value=event.clientY + " y";
  • coordonnées_select();
  • if (event.clientX >= x_init)
  • {
  • largeur_rect=event.clientX - x_init;
  • document.getElementById("rectangle").style.left = x_init;
  • document.getElementById("rectangle").style.width = event.clientX - x_init;
  • }
  • else
  • {
  • largeur_rect=x_init - event.clientX
  • document.getElementById("rectangle").style.left = event.clientX;
  • document.getElementById("rectangle").style.width = x_init - event.clientX;
  • }
  • if (event.clientY >= y_init)
  • {
  • hauteur_rect=event.clientY - y_init;
  • document.getElementById("rectangle").style.top = y_init;
  • document.getElementById("rectangle").style.height = event.clientY - y_init;
  • }
  • else
  • {
  • hauteur_rect=y_init - event.clientY;
  • document.getElementById("rectangle").style.top = event.clientY;
  • document.getElementById("rectangle").style.height = y_init - event.clientY ;
  • }
  • }
  • function slct()
  • {
  • var i=0;
  • var j=0;
  • //commenter la ligne ci-dessous pour ne pas effacer la sélection, lors du onmouseup
  • unslct();
  • for(i=coin_hg[0]+1; i<=coin_hd[0]+1; i++){
  • for(j=coin_hg[1]+1; j<=coin_bg[1]+1; j++){
  • if((j <= nbr_lignes) && (i <= nbr_colonnes) && (j >= 1) && (i >= 1) && (etat_rect==true))
  • document.getElementById(j.toString() + i.toString()).style.background=couleur_ON;
  • }
  • }
  • }
  • function unslct()
  • {
  • var i=0;
  • var j=0;
  • for(i=1; i<=nbr_colonnes; i++){
  • for(j=1; j<=nbr_lignes; j++){
  • document.getElementById(j.toString() + i.toString()).style.background=couleur_OFF;
  • }
  • }
  • }
  • </script>
  • </head>
  • <body onmousemove="souris_rectangle_move()" onmousedown="init_souris_rectangle_down()" onmouseup="init_souris_rectangle_up()">
  • <div id="rectangle" class="rectangle"></div>
  • <div id="masque" class="masque"></div>
  • <div id="console" style="position:absolute; left:40px; top:362px; width:109px; height:57px; z-index:3">
  • <table width="100%" height="100%" border="0" cellpadding="0" cellspacing="0">
  • <tr>
  • <td width="110" height="44" align="left" valign="top">
  • <input name="text" type="text" class="textbox" id="case1_hg" size="10">
  • <input name="text2" type="text" class="textbox" id="case2_hg" size="10">
  • </td>
  • <td width="100%"></td>
  • <td width="110" align="right" valign="top">
  • <input name="text2" type="text" class="textbox" id="case1_hd" size="10">
  • <input name="text2" type="text" class="textbox" id="case2_hd" size="10">
  • </td>
  • </tr>
  • <tr>
  • <td width="110" height="36"></td>
  • <td width="100%">
  • <div align="center">
  • <input name="text2" type="text" class="textbox" id="coordonnéeX" size="4">
  • <input name="text2" type="text" class="textbox" id="coordonnéeY" size="4">
  • </div></td>
  • <td width="110"></td>
  • </tr>
  • <tr>
  • <td width="110" height="23" align="left" valign="bottom">
  • <input name="text2" type="text" class="textbox" id="case1_bg" size="10">
  • <input name="text2" type="text" class="textbox" id="case2_bg" size="10">
  • </td>
  • <td width="100%"></td>
  • <td width="110" align="right" valign="bottom">
  • <input name="text2" type="text" class="textbox" id="case1_bd" size="10">
  • <input name="text2" type="text" class="textbox" id="case2_bd" size="10">
  • </td>
  • </tr>
  • </table>
  • </div>
  • <table width="600" height="300" border="1" cellpadding="1" cellspacing="1">
  • <tr>
  • <td id="11"></td>
  • <td id="12"></td>
  • <td id="13"></td>
  • <td id="14"></td>
  • <td id="15"></td>
  • <td id="16"></td>
  • <td id="17"></td>
  • <td id="18"></td>
  • <td id="19"></td>
  • </tr>
  • <tr>
  • <td id="21"></td>
  • <td id="22"></td>
  • <td id="23"></td>
  • <td id="24"></td>
  • <td id="25"></td>
  • <td id="26"></td>
  • <td id="27"></td>
  • <td id="28"></td>
  • <td id="29"></td>
  • </tr>
  • <tr>
  • <td id="31"></td>
  • <td id="32"></td>
  • <td id="33"></td>
  • <td id="34"></td>
  • <td id="35"></td>
  • <td id="36"></td>
  • <td id="37"></td>
  • <td id="38"></td>
  • <td id="39"></td>
  • </tr>
  • <tr>
  • <td id="41"></td>
  • <td id="42"></td>
  • <td id="43"></td>
  • <td id="44"></td>
  • <td id="45"></td>
  • <td id="46"></td>
  • <td id="47"></td>
  • <td id="48"></td>
  • <td id="49"></td>
  • </tr>
  • <tr>
  • <td id="51"></td>
  • <td id="52"></td>
  • <td id="53"></td>
  • <td id="54"></td>
  • <td id="55"></td>
  • <td id="56"></td>
  • <td id="57"></td>
  • <td id="58"></td>
  • <td id="59"></td>
  • </tr>
  • </table>
  • </body>
  • </html>
<html>
<head>
<title>cadre de sélection</title>
<style type="text/css">
<!--
body {
	margin-left: 0px;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 0px;
	width:100%;
	height:100%;
}
.rectangle {
	position:absolute;
	left:0px;
	top:0px;
	width:100px;
	height:100px;
	z-index:5;
	visibility: hidden;
	font-size: 0px;
	border: 1px dashed;
}
.masque {
	position:absolute;
 	left:0px;
  	top:0px;
   	width:100%;
    height:100%;
	z-index:4;
}
.textbox {
	font-family: Verdana, Arial, Helvetica, sans-serif;
	font-size: 9px;
	font-style: italic;
}
-->
</style>
<script language="javascript">

var hauteur=300;
var largeur=600;
var nbr_colonnes=9;
var nbr_lignes=5;
var couleur_ON="#CCFFFF";
var couleur_OFF="#FFFFCC";

var x_init=0;
var y_init=0;
var largeur_rect=0;
var hauteur_rect=0;
var etat_rect = false;
var coin_hg = new Array(0,0); // haut gauche
var coin_hd = new Array(0,0); // haut droite
var coin_bg = new Array(0,0); // bas gauche
var coin_bd = new Array(0,0); // bas droite

function coordonnées_select()
{
	var i=0;
	var j=0;
	var cpt_col=0;
	var cpt_lig = 0;
	var str;
	
	//gestion des coordonnées X
	if (event.clientX >= x_init)
	{
		coin_hg[0] = Math.floor(x_init/(largeur/nbr_colonnes));
		coin_hd[0] = Math.floor((x_init+largeur_rect)/(largeur/nbr_colonnes));
		coin_bg[0] = Math.floor(x_init/(largeur/nbr_colonnes));
		coin_bd[0] = Math.floor((x_init+largeur_rect)/(largeur/nbr_colonnes));
	}
	else
	{
		coin_hg[0] = Math.floor((x_init-largeur_rect)/(largeur/nbr_colonnes));
		coin_hd[0] = Math.floor(x_init/(largeur/nbr_colonnes));
		coin_bg[0] = Math.floor((x_init-largeur_rect)/(largeur/nbr_colonnes));
		coin_bd[0] = Math.floor(x_init/(largeur/nbr_colonnes));
	}
		
	//gestion des coordonnées Y
	if (event.clientY >= y_init)
	{
		coin_hg[1] = Math.floor(y_init/(hauteur/nbr_lignes));
		coin_hd[1] = Math.floor(y_init/(hauteur/nbr_lignes));
		coin_bg[1] = Math.floor((y_init+hauteur_rect)/(hauteur/nbr_lignes));
		coin_bd[1] = Math.floor((y_init+hauteur_rect)/(hauteur/nbr_lignes));
	}
	else
	{
		coin_hg[1] =  Math.floor((y_init-hauteur_rect)/(hauteur/nbr_lignes));
		coin_hd[1] =  Math.floor((y_init-hauteur_rect)/(hauteur/nbr_lignes));
		coin_bg[1] =  Math.floor(y_init/(hauteur/nbr_lignes));
		coin_bd[1] =  Math.floor(y_init/(hauteur/nbr_lignes));
	}
	
	slct();
	
	document.getElementById("case1_hg").value = coin_hg[0];
	document.getElementById("case1_hd").value = coin_hd[0];
	document.getElementById("case1_bg").value = coin_bg[0];
	document.getElementById("case1_bd").value = coin_bd[0];
	document.getElementById("case2_hg").value = coin_hg[1];
	document.getElementById("case2_hd").value = coin_hd[1];
	document.getElementById("case2_bg").value = coin_bg[1];
	document.getElementById("case2_bd").value = coin_bd[1];
}

function init_souris_rectangle_up()
{
document.getElementById("rectangle").style.visibility="hidden";
etat_rect=false;


unslct()
}

function init_souris_rectangle_down()
{
x_init=event.clientX;
y_init=event.clientY;

//initialisation du rectangle sans attendre le 1er mouvement de souris
souris_rectangle_move();
etat_rect=true;
document.getElementById("rectangle").style.visibility="visible";
}

function souris_rectangle_move()
{
	//affichage des coordonnées
	document.getElementById("coordonnéeX").value=event.clientX + " x";
	document.getElementById("coordonnéeY").value=event.clientY + " y";
	
	coordonnées_select();
	
	if (event.clientX >= x_init)
	{
	largeur_rect=event.clientX - x_init;
	document.getElementById("rectangle").style.left = x_init;
	document.getElementById("rectangle").style.width = event.clientX - x_init;
	}
	else
	{
	largeur_rect=x_init - event.clientX
	document.getElementById("rectangle").style.left = event.clientX;
	document.getElementById("rectangle").style.width = x_init - event.clientX;
	}
	
	if (event.clientY >= y_init)
	{
	hauteur_rect=event.clientY - y_init;
	document.getElementById("rectangle").style.top = y_init;
	document.getElementById("rectangle").style.height = event.clientY - y_init;
	}
	else
	{
	hauteur_rect=y_init - event.clientY;
	document.getElementById("rectangle").style.top = event.clientY;
	document.getElementById("rectangle").style.height = y_init - event.clientY  ;
	}
}

function slct()
{
	var i=0;
	var j=0;
	
	//commenter la ligne ci-dessous pour ne pas effacer la sélection, lors du onmouseup
	unslct();
	
		for(i=coin_hg[0]+1; i<=coin_hd[0]+1; i++){
			for(j=coin_hg[1]+1; j<=coin_bg[1]+1; j++){
				if((j <= nbr_lignes) && (i <= nbr_colonnes) && (j >= 1) && (i >= 1) && (etat_rect==true))
					document.getElementById(j.toString() + i.toString()).style.background=couleur_ON;
			}
		}
}

function unslct()
{
	var i=0;
	var j=0;
	
		for(i=1; i<=nbr_colonnes; i++){
			for(j=1; j<=nbr_lignes; j++){
					document.getElementById(j.toString() + i.toString()).style.background=couleur_OFF;
			}
		}
}
</script>

</head>
<body  onmousemove="souris_rectangle_move()" onmousedown="init_souris_rectangle_down()" onmouseup="init_souris_rectangle_up()"> 

<div id="rectangle" class="rectangle"></div> 
<div id="masque" class="masque"></div>

<div id="console" style="position:absolute; left:40px; top:362px; width:109px; height:57px; z-index:3">
  <table width="100%" height="100%" border="0" cellpadding="0" cellspacing="0">
    <tr>
      <td width="110" height="44" align="left" valign="top">
        <input name="text" type="text" class="textbox" id="case1_hg" size="10">
        <input name="text2" type="text" class="textbox" id="case2_hg" size="10">
      </td>
      <td width="100%"></td>
      <td width="110" align="right" valign="top">
        <input name="text2" type="text" class="textbox" id="case1_hd" size="10">
        <input name="text2" type="text" class="textbox" id="case2_hd" size="10">
      </td>
    </tr>
    <tr>
      <td width="110" height="36"></td>
      <td width="100%">
        <div align="center">
          <input name="text2" type="text" class="textbox" id="coordonnéeX" size="4">
          <input name="text2" type="text" class="textbox" id="coordonnéeY" size="4">
      </div></td>
      <td width="110"></td>
    </tr>
    <tr>
      <td width="110" height="23" align="left" valign="bottom">
        <input name="text2" type="text" class="textbox" id="case1_bg" size="10">
        <input name="text2" type="text" class="textbox" id="case2_bg" size="10">
      </td>
      <td width="100%"></td>
      <td width="110" align="right" valign="bottom">
        <input name="text2" type="text" class="textbox" id="case1_bd" size="10">
        <input name="text2" type="text" class="textbox" id="case2_bd" size="10">
      </td>
    </tr>
  </table>
</div>

<table width="600" height="300"  border="1" cellpadding="1" cellspacing="1"> 
  <tr> 
    <td id="11"></td> 
    <td id="12"></td> 
    <td id="13"></td> 
    <td id="14"></td> 
    <td id="15"></td> 
    <td id="16"></td> 
    <td id="17"></td> 
    <td id="18"></td> 
    <td id="19"></td> 
  </tr> 
  <tr> 
    <td id="21"></td> 
    <td id="22"></td> 
    <td id="23"></td> 
    <td id="24"></td> 
    <td id="25"></td> 
    <td id="26"></td> 
    <td id="27"></td> 
    <td id="28"></td> 
    <td id="29"></td> 
  </tr> 
  <tr> 
    <td id="31"></td> 
    <td id="32"></td> 
    <td id="33"></td> 
    <td id="34"></td> 
    <td id="35"></td> 
    <td id="36"></td> 
    <td id="37"></td> 
    <td id="38"></td> 
    <td id="39"></td>
  </tr> 
  <tr> 
    <td id="41"></td> 
    <td id="42"></td> 
    <td id="43"></td> 
    <td id="44"></td> 
    <td id="45"></td> 
    <td id="46"></td> 
    <td id="47"></td> 
    <td id="48"></td> 
    <td id="49"></td> 
  </tr> 
  <tr> 
    <td id="51"></td> 
    <td id="52"></td> 
    <td id="53"></td> 
    <td id="54"></td> 
    <td id="55"></td> 
    <td id="56"></td> 
    <td id="57"></td> 
    <td id="58"></td> 
    <td id="59"></td> 
  </tr>
</table> 
</body>
</html>

 Conclusion

Pour ce qui est des bugs, je n'en conné pas (ca va durer). Sinon pouvez vous me rendre un service en éxécutant cette page sur différents OS et navigateurs. Juste pour apprécier la compatibilité du code. Merci à vous ;)
Autrement, une mise à jour pointera surement le bout de son nez, dans quelques temps.

Et puis n'oubliez pas de me donner votre opinion sur ce code.

Ciao et merci
Pierre DULOY


 Historique

20 mai 2005 16:51:54 :
ajout de la capture

 Sources du même auteur

Source avec une capture RECTANGLE OU CADRE DE SÉLECTION

 Sources de la même categorie

Source avec Zip JDMATH-MINI.JS : GÉNÉRATION D'EXPRESSION MATHÉMATIQUE par jdmcreator
Source avec une capture SPHERE 3D DÉFORMABLE par phm
Source avec Zip Source avec une capture EFFET DE ROTATION A 360° D'IMAGE AVEC ACCELERATION DECELERAT... par kazma
Source avec Zip Source avec une capture PETIT LOGICIEL DE DESSIN, RETOUCHE AVEC CANVAS par kazma
Source avec Zip Source avec une capture CALCULATRICE HEURE par m22001111

Commentaires et avis

Commentaire de garfield90 le 21/05/2005 01:00:38

Salut,

marche pas sous firefox ni sous IE sur un PC classique, ou alors je sais pas faire un Copier-Coller

au fait, n'oublies pas les &nbsp; dans tes <td>&nbsp;</td>

Sur ce, pas de note car pas tester

A plus et mets ton source en ZIP, ca evites les pb de copier-coller

Commentaire de darkman2 le 21/05/2005 10:41:56

il a raison
ca va ns éviter de faire c/c
il y a ptit problémé dans ton prog
lorsqu'on selectionne tte la partie de la page
ces coordonnées affichent 0;0

c po clai ton prog
et en + il va me servir à rien ton prog

Commentaire de la_pin le 21/05/2005 13:12:05

marche pas sur mozilla mais sinon, marche sans pb sur IE, mais à part ça, je trouve ce petit prog bien sympa ^^

Commentaire de bichonade le 24/05/2005 11:44:57

slt...je cherchais également à faire une application comme cela mais j'aimerais conserver le rectangle une fois que l'utilisateur l'a dessiné...Comment est-ce possible ?
A terme, j'aimerai arriver a permettre à un utilisteur de dessiner un polygone....pô facile tous les jours moi je vous le dit..d'autan plus que j'ai essayé avec la bibliothèque wz_jsgraphics.js conseillée sur un des forum mais sans plus de succès..si une personne kelkelle soit pouvait me donner un coup de main, si vous connaissez des librairies javascript pour réaliser cela, ca serait sympa de me les faire parvenir...merci bcp a tous ceux qui auront pris le temps de lire ce message..

Commentaire de oolon le 07/06/2005 15:11:54

Ce script n'est pas mal du tout, c'est ce que je recherchais à part que j'aurais voulu que les cases sélectionnées restent de la couleur de la sélection une fois le bouton de la souris relaché... cela est-il possible ? Si oui comment ?
D'autre part, il n'est pas compatible avec firefox, vous savez à quoi cela est du ? Qu'est-ce qui n'est pas géré par le navigateur ???
Merci d'avance !

Commentaire de duckaurore le 12/01/2006 10:33:29

Bien sympa ton code. C'est ce que je cherche. Mais je voudrai faire cette sélection sur une image, et je n'arrive pas à comprendre comment je dois faire. Quelqu'un peut-il m'aider, svp?
Merci d'avance!

Commentaire de stfou le 06/03/2007 16:01:21

Gé-ni-al ta source, mais met un zip.
10/10

 Ajouter un commentaire




Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 3,682 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales