Eenvoudige geanimeerde analoog horlosie in Tailwind.css

Hoe om 'n baie eenvoudige analoog horlosie met animasie slegs in Tailwind.css te skep

'N Horlosie -stertwind

Terwyl ek die detailbladsy ontwerp het vir projekte waaraan ek gewerk het (beskikbaar op my portefeulje-bladsy), het ek ook 'n eenvoudige geanimeerde analoog horlosie geïmplementeer wat langs die projek se tydsduur weergegee word.

Omdat ek geen nuwe eksterne biblioteke of video's wou gebruik nie, het ek besluit om die klok te implementeer via Tailwind.css en die wonderlike animasiehulpmiddels.

Kode voorbeelde

Daar is nie veel meer om te sê nie, want ek het gedink dat dit die beste vir u sou wees as ek net 'n paar kodevoorbeelde gee vir hergebruik.

Die uitleg in elke voorbeeld is byna dieselfde, baie dieselfde. Ek gee net 'n paar div-bokse weer deur absolute posisionering op mekaar. Aangesien elke boks slegs die kleinste breedte beskikbaar het, blyk dit dat die wysers op die klok sigbaar is.

Die laaste voorbeeld toon hoe u om 12 uur moet begin. Die eerste twee voorbeelde begin elk om 3 uur, soos dit in die ry uiteengesit is.

Voorbeeld 1: Mees eenvoudige horlosie

Image dbead4b8e463

export function Clock() {
  return (
    <div className="flex justify-center py-10 group">
      <div className="relative flex items-center justify-end w-20 h-20 overflow-hidden bg-gray-900 rounded-full ">
        <div className="absolute w-1/2 h-1 bg-white rounded-full origin-left -rotate-12 group-hover:rotate-[215deg] duration-1000 ease-in-out" />

        <div className="absolute w-1/2 h-1  origin-left rotate-[70] group-hover:rotate-[340deg] duration-1000 ease-in-out">
          <div className="w-2/3 h-full bg-white rounded-full" />
        </div>

        <div className="absolute flex justify-center flex-1 w-full">
          <div className="w-1 h-1 bg-white rounded-full" />
        </div>
      </div>
    </div>
  );
}

Voorbeeld 2: horlosie met rand en aanwysers

Image 06597167696f

import React from "react";
// Note that I'm using 'clsx' for
// composing classnames.
import clsx from "clsx";

export function Clock() {
  return (
    <div className="relative flex items-center justify-end w-20 h-20 overflow-hidden rounded-full ring-gray-600 ring-1">
      {Array.from({ length: 8 }, (_, i) => (
        <div
          key={i}
          style={{ height: 1 }}
          className={clsx("absolute w-1/2 origin-left flex justify-end", {
            "rotate-0": i === 0,
            "rotate-45": i === 1,
            "rotate-90": i === 2,
            "rotate-[135deg]": i === 3,
            "rotate-180": i === 4,
            "rotate-[225deg]": i === 5,
            "rotate-[270deg]": i === 6,
            "rotate-[315deg]": i === 7,
          })}>
          <div className="w-1/3 h-full bg-gray-600 rounded-full" />
        </div>
      ))}

      <div className="absolute w-1/2 h-1 bg-gray-300 rounded-full origin-left -rotate-12 group-hover:rotate-[215deg] duration-1000 ease-in-out" />

      <div className="absolute w-1/2 h-1  origin-left rotate-[85deg] group-hover:rotate-[340deg] duration-1000 ease-in-out">
        <div className="w-2/3 h-full bg-gray-300 rounded-full" />
      </div>

      <div className="absolute flex justify-center flex-1 w-full">
        <div className="w-1 h-1 bg-gray-300 rounded-full" />
      </div>
    </div>
  );
}

Voorbeeld 3: horlosie wat om middernag begin

Image c2d6bdde9e1e

export function Clock() {
  return (
    <div className="flex justify-center py-10 group">
      <div className="relative flex flex-col items-center justify-start w-20 h-20 overflow-hidden bg-gray-900 rounded-full ">
        <div className="absolute w-1 duration-1000 ease-in-out origin-bottom bg-gradient-to-t from-white to-red-400 rounded-full h-1/2 group-hover:rotate-[200deg]" />

        <div className="absolute h-1/2 w-1 origin-bottom rotate-[55deg] group-hover:rotate-[340deg] duration-1000 ease-in-out flex flex-col justify-end">
          <div className="w-full rounded-full bg-gradient-to-t from-white to-blue-400 h-2/3" />
        </div>

        <div className="absolute flex items-center justify-center flex-1 w-full h-full">
          <div className="w-1 h-1 bg-white rounded-full" />
        </div>
      </div>
    </div>
  );
}