- L’équipe « Vision et Analyse de Données » est une équipe du laboratoire L@bISEN de l’ISEN
Yncréa Ouest. L’équipe mène une activité de R&D pour la conception de plateformes
technologiques d’observations et d’analyses à partir de réseaux de capteurs intelligents.
Yncréa Ouest. L’équipe mène une activité de R&D pour la conception de plateformes
technologiques d’observations et d’analyses à partir de réseaux de capteurs intelligents.
Fil d'actualité
diff --git a/membres.html b/membres.html index 832b333..92c4e6b 100644 --- a/membres.html +++ b/membres.html @@ -46,8 +46,11 @@Enseignants chercheurs permanents:
Brest:
-Météo a Brest:
- +Venir en train + bus:
A partir de la gare de Brest, prendre le bus 03 en direction Lambézellecde Gouesnou à l’arrêt Gambetta Gare jusqu'à l’arrêt Gay Lussac.
Venir en voiture:
@@ -59,8 +58,7 @@Nantes:
-Météo a Nantes:
- +Venir en train + bus:
A partir de la gare de Nantes, prendre le tram 1 en direction Beaujoire à l’arrêt Gare Nord jusqu'à l’arrêt Halvêque puis rejoindre l’arrêt de bus Boulodrome Halvêque de la ligne 95. Descendre à l’arrêt ICAM puis marcher jusqu’au campus.
Venir en voiture:
@@ -71,8 +69,7 @@Rennes:
-Météo a Rennes:
- +Venir en train + bus:
A partir de la gare de Rennes, prendre le bus C4 en direction Grand Quartier à l’arrêt Musée Beaux Arts jusqu'à l’arrêt Préfecture puis marcher jusqu’au campus.
Venir en voiture:
@@ -83,8 +80,7 @@Caen:
-Météo a Caen:
- +Venir en train + bus:
A partir de la gare de Caen, prendre le tram 1 en direction HEROUVILLE St-Clair à l’arrêt Gare SNCF jusqu'à l’arrêt Bernières, Caen puis marcher jusqu’au campus.
Venir en voiture:
diff --git a/src/css/style.css b/src/css/style.css index 8a97c06..e7d043d 100644 --- a/src/css/style.css +++ b/src/css/style.css @@ -35,7 +35,7 @@ img{ #who_we_are{ width: 100%; height: 100%; - color: white; + color: red; text-align: center; } @@ -72,4 +72,8 @@ img{ #img_hover{ width: auto; +} + +#LabHidden{ + display: none; } \ No newline at end of file diff --git a/src/css/style_membres.css b/src/css/style_membres.css index c80eb1c..f6f00e6 100644 --- a/src/css/style_membres.css +++ b/src/css/style_membres.css @@ -165,3 +165,14 @@ h2{ text-decoration: none; cursor: pointer; } + +.image-container{ + position: relative; +} + +.image-container canvas { + position: absolute; + top: 10px; + left: 75px; + border-radius: 50%; +} \ No newline at end of file diff --git a/src/js/InfosEtContact/plan/plan.js b/src/js/InfosEtContact/plan/plan.js index 80d345a..f057161 100644 --- a/src/js/InfosEtContact/plan/plan.js +++ b/src/js/InfosEtContact/plan/plan.js @@ -168,7 +168,7 @@ document.addEventListener('DOMContentLoaded', function() { condition: data.weather[0].description }; - document.getElementById(elementId).innerHTML = `Météo à ${city} : ${weatherData.temperature}°C, ${weatherData.condition}`; + document.getElementById(elementId).innerHTML = `Météo à ${city} :
${weatherData.temperature}°C, ${weatherData.condition}`; }) .catch(error => { console.log('Une erreur s\'est produite :', error); @@ -176,9 +176,9 @@ document.addEventListener('DOMContentLoaded', function() { } // Appeler la fonction pour chaque ville - getWeather('Brest', 'weatherWidgetBrest'); - getWeather('Nantes', 'weatherWidgetNantes'); - getWeather('Rennes', 'weatherWidgetRennes'); - getWeather('Caen', 'weatherWidgetCaen'); + getWeather('Brest', 'weatherBrest'); + getWeather('Nantes', 'weatherNantes'); + getWeather('Rennes', 'weatherRennes'); + getWeather('Caen', 'weatherCaen'); }); diff --git a/src/js/index/index.js b/src/js/index/index.js index ff7ed2c..1361704 100644 --- a/src/js/index/index.js +++ b/src/js/index/index.js @@ -1,11 +1,15 @@ function displayWord() { - const words = document.getElementById('who_we_are').textContent.trim().split(' '); - + const words = document.getElementById('LabHidden').textContent.trim().split(' '); words.forEach((word, index) => { const wordElement = document.createElement('span'); wordElement.classList.add('word'); wordElement.innerText = word; wordElement.style.transitionDelay = `${index * 100}ms`; + //Si le module d'index par 15 atteint 0, on ajoute un+ if (index % 15 === 0) { + const brElement = document.createElement('br'); + document.getElementById('who_we_are').appendChild(brElement); + } document.getElementById('who_we_are').appendChild(wordElement); // Ajouter un espace après chaque mot, sauf pour le dernier mot @@ -15,16 +19,6 @@ function displayWord() { document.getElementById('who_we_are').appendChild(spaceElement); } - // Vérifier s'il y a un élément
dans le texte - const nextElement = wordElement.nextElementSibling; - if (nextElement && nextElement.tagName === 'br') { - console.log('ca passe ici') - const spaceElement = document.createElement('span'); - spaceElement.innerHTML = ' '; - document.getElementById('who_we_are').appendChild(spaceElement); - console.log('la aussi') - } - setTimeout(() => { wordElement.classList.add('show'); }, 1000); diff --git a/src/js/membres/membres.js b/src/js/membres/membres.js index 715eda8..1fe292a 100644 --- a/src/js/membres/membres.js +++ b/src/js/membres/membres.js @@ -79,15 +79,121 @@ document.addEventListener('DOMContentLoaded', function() { document.body.appendChild(editButton); }, 2000); -/* - document.addEventListener('mouseover', function(e){ - const ayoub = document.getElementById('AyoubKarine'); - const bubbles = document.createElement('span'); - bubbles.style.left = e.offsetX + 'px'; - bubbles.style.top = e.offsetY + 'px'; - ayoub.appendChild(bubbles); - }); - */ + function blackCard() { + + 'use strict'; + + var isDrawing, lastPoint; + var container = document.getElementById('js-container'), + canvas = document.getElementById('js-canvas'), + canvasWidth = canvas.width, + canvasHeight = canvas.height, + ctx = canvas.getContext('2d'), + image = new Image(), + brush = new Image(); + + // base64 Workaround because Same-Origin-Policy + image.src = 'https://beeimg.com/images/b61265551431.png'; + image.onload = function() { + ctx.drawImage(image, 0, 0); + // Show the form when Image is loaded. + document.querySelectorAll('.Ayoub')[0].style.visibility = 'visible'; + }; + brush.src = ''; + + canvas.addEventListener('mousedown', handleMouseDown, false); + canvas.addEventListener('mouseover', handleMouseDown, false); + canvas.addEventListener('mousemove', handleMouseMove, false); + canvas.addEventListener('touchmove', handleMouseMove, false); + canvas.addEventListener('mouseup', handleMouseUp, false); + canvas.addEventListener('touchend', handleMouseUp, false); + + function distanceBetween(point1, point2) { + return Math.sqrt(Math.pow(point2.x - point1.x, 2) + Math.pow(point2.y - point1.y, 2)); + } + + function angleBetween(point1, point2) { + return Math.atan2( point2.x - point1.x, point2.y - point1.y ); + } + + // Only test every `stride` pixel. `stride`x faster, + // but might lead to inaccuracy + function getFilledInPixels(stride) { + if (!stride || stride < 1) { stride = 1; } + + var pixels = ctx.getImageData(0, 0, canvasWidth, canvasHeight), + pdata = pixels.data, + l = pdata.length, + total = (l / stride), + count = 0; + + // Iterate over all pixels + for(var i = count = 0; i < l; i += stride) { + if (parseInt(pdata[i]) === 0) { + count++; + } + } + + return Math.round((count / total) * 100); + } + + function getMouse(e, canvas) { + var offsetX = 0, offsetY = 0, mx, my; + + if (canvas.offsetParent !== undefined) { + do { + offsetX += canvas.offsetLeft; + offsetY += canvas.offsetTop; + } while ((canvas = canvas.offsetParent)); + } + + mx = (e.pageX || e.touches[0].clientX) - offsetX; + my = (e.pageY || e.touches[0].clientY) - offsetY; + + return {x: mx, y: my}; + } + + function handlePercentage(filledInPixels) { + filledInPixels = filledInPixels || 0; + console.log(filledInPixels + '%'); + if (filledInPixels > 50) { + canvas.parentNode.removeChild(canvas); + } + } + + function handleMouseDown(e) { + isDrawing = true; + lastPoint = getMouse(e, canvas); + } + + function handleMouseMove(e) { + if (!isDrawing) { return; } + + e.preventDefault(); + + var currentPoint = getMouse(e, canvas), + dist = distanceBetween(lastPoint, currentPoint), + angle = angleBetween(lastPoint, currentPoint), + x, y; + + for (var i = 0; i < dist; i++) { + x = lastPoint.x + (Math.sin(angle) * i) - 25; + y = lastPoint.y + (Math.cos(angle) * i) - 25; + ctx.globalCompositeOperation = 'destination-out'; + ctx.drawImage(brush, x, y); + } + + lastPoint = currentPoint; + handlePercentage(getFilledInPixels(32)); + } + + function handleMouseUp(e) { + isDrawing = false; + } + + } + + blackCard(); }); function addMember() {