Rumah hujung hadapan web tutorial js JavaScript html5 kanvas lukisan kesan jam (2)_kemahiran javascript

JavaScript html5 kanvas lukisan kesan jam (2)_kemahiran javascript

May 16, 2016 pm 03:07 PM
canvas html5 javascript

Untuk H5, kanvas boleh dikatakan sebagai ciri yang paling tersendiri Dengannya, kita boleh melukis pelbagai grafik di halaman web, membuat beberapa permainan kecil dan sebagainya. Terdapat banyak tutorial tentang cara menggunakan tag kanvas di Internet, jadi saya tidak akan memperkenalkannya di sini. Hari ini kita akan menggunakan kanvas untuk membuat jam kecil. Kod lengkap ada di sinihttps://github.com/wwervin72/HTML5-Clock.

Pertama sekali, saya menggunakan dua kanvas pada halaman ini, satu untuk melukis dail dan skala jam statik, dan satu lagi untuk melukis tiga jarum jam, dan kemudian menggunakan kedudukan untuk menjadikannya bertindih. Kemudian tidak ada apa-apa untuk dikatakan di sini, kod itu dilampirkan di bawah.

1

2

3

4

5

6

<canvas id="plate">

 画表盘

</canvas>

<canvas id="needles">

 画时针

</canvas>

Salin selepas log masuk

1

2

3

4

5

6

7

8

9

var plate=document.getElementById('plate');

var needles=document.getElementById('needles');

needles.setAttribute('style','position:absolute;top:8px;left:8px;'); //这里因为chrome里面,body的magin值为8px,所以我这里就没设为0了。

var cntP=plate.getContext('2d');

var cntH=needles.getContext('2d');

plate.width=800;

plate.height=500;

needles.width=800;

needles.height=500;

Salin selepas log masuk

Sekarang persiapan selesai, kami bersedia untuk melukis jam. Saya mula-mula menentukan pembina yang melukis muka jam.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

function drawclock(cnt,radius,platelen,linewidth,numLen,NUMLEN){

 this.cnt=cnt;

 this.radius=radius;

 this.platelen=platelen;

 this.linewidth=linewidth;

 this.numLen=numLen;

 this.NUMLEN=NUMLEN;

 this.getCalibCoor=function(i){

 //获得表盘刻度两端的坐标

 var X=200+this.radius*Math.sin(6*i*Math.PI/180);

 var Y=200-this.radius*Math.cos(6*i*Math.PI/180);

 var x=200+(this.radius-this.platelen)*Math.sin(6*i*Math.PI/180);

 var y=200-(this.radius-this.platelen)*Math.cos(6*i*Math.PI/180);

 

 // 获得分钟数字的坐标

 var numx=200+(this.radius-this.platelen-this.numLen)*Math.sin(6*i*Math.PI/180);

 var numy=200-(this.radius-this.platelen-this.numLen)*Math.cos(6*i*Math.PI/180);

 //获得小时数字的坐标

 var numX=200+(this.radius-this.platelen-this.NUMLEN)*Math.sin(6*i*Math.PI/180);

 var numY=200-(this.radius-this.platelen-this.NUMLEN)*Math.cos(6*i*Math.PI/180);

 return {X:X,Y:Y,x:x,y:y,numx:numx,numy:numy,numX:numX,numY:numY};

 };

 this.drawCalibration=function(){ //画刻度

 for(var i=0,coorObj;i<60;i++){

  coorObj=this.getCalibCoor(i);

  this.cnt.beginPath();

  this.cnt.moveTo(coorObj.X,coorObj.Y);

  this.cnt.lineTo(coorObj.x,coorObj.y);

  this.cnt.closePath();

 

  this.cnt.lineWidth=this.linewidth;

  this.cnt.strokeStyle='#ddd';

  i%5==0&&(this.cnt.strokeStyle='#aaa')

  &&(this.cnt.lineWidth=this.linewidth*2);

  i%15==0&&(this.cnt.strokeStyle='#999')

  &&(this.cnt.lineWidth=this.linewidth*3);

  this.cnt.stroke();

 

  this.cnt.font='10px Arial';

  this.cnt.fillStyle='rgba(0,0,0,.2)';

  this.cnt.fillText(i,coorObj.numx-7,coorObj.numy+3);

  i%5==0&&(this.cnt.fillStyle='rgba(0,0,0,.5)')

  &&(this.cnt.font='18px Arial')

  &&(this.cnt.fillText(i/5,coorObj.numX-5,coorObj.numY+5));

 }

 };

}

     var clock=new drawclock(cntP,200,5,1,10,25); //实例化一个表盘对象

     clock.drawCalibration();

Salin selepas log masuk

Bahagian yang paling penting di sini adalah untuk mendapatkan koordinat skala dan lukisan digital. Saya meletakkan titik permulaan skala pada tepi dail, kemudian menolak panjang skala daripada jejari dail untuk mendapatkan lokasi titik akhir skala, dan kemudian menggunakan sudut dan fungsi trigonometri untuk mendapatkan koordinat dua titik. Akhir sekali, anda boleh melukis skala dail. Kaedah yang sama digunakan untuk melukis nombor pada dail di bawah. Pusat dail di sini diletakkan pada (200,200). Pada ketika ini kita telah melukis muka jam statik.

Di bawah saya mentakrifkan pembina untuk melukis penunjuk jam.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

function clockNeedle(cnt,R,lineWidth,strokeStyle,lineCap,obj){

  this.R=R;

  this.cnt=cnt;

  this.lineWidth=lineWidth;

  this.strokeStyle=strokeStyle;

  this.lineCap=lineCap;

  this.obj=obj;

  this.getNeedleCoor=function(i){

  var X=200+this.R*0.8*Math.sin(i); //起点的坐标

  var Y=200-this.R*0.8*Math.cos(i);

 

  var x=200-20*Math.sin(i); //终点的坐标

  var y=200+20*Math.cos(i);

  return {X:X,Y:Y,x:x,y:y};

  };

  this.drawNeedle=function(){

  var d=new Date().getTime();

  var angle;

  switch(this.obj){

   case 0:

   angle=(d/3600000%24+8)/12*360*Math.PI/180;

   break;

   case 1:

   angle=d/60000%60/60*360*Math.PI/180;

   break;

   case 2:

   angle=d/1000%60/60*360*Math.PI/180;

   break;

  }

  var coorobj=this.getNeedleCoor(angle);

  this.cnt.beginPath();

  this.cnt.moveTo(coorobj.x,coorobj.y);

  this.cnt.lineTo(coorobj.X,coorobj.Y);

  // this.cnt.closePath();

 

  this.cnt.lineWidth=this.lineWidth;

  this.cnt.strokeStyle=this.strokeStyle;

  this.cnt.lineCap=this.lineCap;

  this.cnt.stroke();

  }

 }

Salin selepas log masuk


Terdapat dua perkara yang perlu dinyatakan di sini: 1. Apabila kita mendapat milisaat masa semasa dan kemudian menukarnya kepada jam, apabila kita mengambil modulo 24 untuk mengira jam dalam sehari, kita perlu menambah 8 di sini . Jika Jika anda ingin menggunakan atribut lineCap, jangan gunakan closePath() apabila menetapkan laluan di atas.

Pada ketika ini kita juga memerlukan kaedah untuk melukis penunjuk dan menjadikannya kelihatan seperti ia boleh berputar:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

function draw(){

  cntH.clearRect(0,0,needles.width,needles.height);

  var mzneedle=new clockNeedle(cntH,200,1,'rgba(0,0,0,.5)','round',2);

  //最后一个参数0代表画时针,1画分针,2画秒针

  var fzneedle=new clockNeedle(cntH,80,3,'rgba(0,0,0,.4)','round',0);

  var szneedle=new clockNeedle(cntH,140,2,'rgba(0,0,0,.3)','round',1);

  mzneedle.drawNeedle();

  fzneedle.drawNeedle();

  szneedle.drawNeedle();

  cntH.arc(200,200,5,0,2*Math.PI);

  cntH.fillStyle='rgba(0,0,0,.5)';

  cntH.fill();

 }

 setInterval(draw,1);

Salin selepas log masuk

Gambar jam dilampirkan di bawah:

Di atas adalah keseluruhan kandungan artikel ini, saya harap ia akan membantu kajian semua orang.

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Sempadan Jadual dalam HTML Sempadan Jadual dalam HTML Sep 04, 2024 pm 04:49 PM

Panduan untuk Sempadan Jadual dalam HTML. Di sini kita membincangkan pelbagai cara untuk menentukan sempadan jadual dengan contoh Sempadan Jadual dalam HTML.

Jadual Bersarang dalam HTML Jadual Bersarang dalam HTML Sep 04, 2024 pm 04:49 PM

Ini ialah panduan untuk Nested Table dalam HTML. Di sini kita membincangkan cara membuat jadual dalam jadual bersama-sama dengan contoh masing-masing.

HTML jidar-kiri HTML jidar-kiri Sep 04, 2024 pm 04:48 PM

Panduan untuk HTML margin-kiri. Di sini kita membincangkan gambaran keseluruhan ringkas tentang HTML margin-left dan Contoh-contohnya bersama-sama dengan Pelaksanaan Kodnya.

Susun Atur Jadual HTML Susun Atur Jadual HTML Sep 04, 2024 pm 04:54 PM

Panduan untuk Susun Atur Jadual HTML. Di sini kita membincangkan Nilai Susun Atur Jadual HTML bersama-sama dengan contoh dan output n perincian.

Pemegang Tempat Input HTML Pemegang Tempat Input HTML Sep 04, 2024 pm 04:54 PM

Panduan untuk Pemegang Tempat Input HTML. Di sini kita membincangkan Contoh Pemegang Tempat Input HTML bersama-sama dengan kod dan output.

Senarai Tertib HTML Senarai Tertib HTML Sep 04, 2024 pm 04:43 PM

Panduan kepada Senarai Tertib HTML. Di sini kami juga membincangkan pengenalan senarai dan jenis Tertib HTML bersama-sama dengan contoh mereka masing-masing

Memindahkan Teks dalam HTML Memindahkan Teks dalam HTML Sep 04, 2024 pm 04:45 PM

Panduan untuk Memindahkan Teks dalam HTML. Di sini kita membincangkan pengenalan, cara teg marquee berfungsi dengan sintaks dan contoh untuk dilaksanakan.

Butang onclick HTML Butang onclick HTML Sep 04, 2024 pm 04:49 PM

Panduan untuk Butang onclick HTML. Di sini kita membincangkan pengenalan, kerja, contoh dan onclick Event masing-masing dalam pelbagai acara.

See all articles