kitty-hexgrid

1.2.9 • Public • Published

😸 kitty-hexgrid

Downloads

React components to build interactive hexagons grids. It uses SVG which makes it fast, scalable and easy to apply custom styles. You can easily customize the layout of the grid just by configuration.

Component-based approach allows you to customize the grid shape to suit your needs or even apply your own components / SVG elements to it. You can use pre-defined generator to create certain shape grid or you may build totally your own grid to the shape you wish, while still keeping it under control and interactive.

Pre-requisites

You should be familiar with Node + NPM, React and ES6 to use this library. Library also depends heavily on HTML5 features (mostly SVG) which all might not be supported by every browser yet.

Getting Started

Install it via npm:

npm i kitty-hexgrid

Example

import { HexGrid, Layout, Hexagon, Text, Pattern, Path, Hex } from 'kitty-hexgrid';
import './App.css';

class App extends Component {
  render() {
    return (
      <div className="App">
        <HexGrid width={1200} height={800} viewBox="-50 -50 100 100">
          {/* Grid with manually inserted hexagons */}
          <Layout size={{ x: 10, y: 10 }} flat={true} spacing={1.1} origin={{ x: 0, y: 0 }}>
            <Hexagon q={0} r={0} s={0} />
            {/* Using pattern (defined below) to fill the hexagon */}
            <Hexagon q={0} r={-1} s={1} fill="pat-1" />
            <Hexagon q={0} r={1} s={-1} />
            <Hexagon q={1} r={-1} s={0}>
              <Text>1, -1, 0</Text>
            </Hexagon>
            <Hexagon q={1} r={0} s={-1}>
              <Text>1, 0, -1</Text>
            </Hexagon>
            {/* Pattern and text */}
            <Hexagon q={-1} r={1} s={0} fill="pat-2">
              <Text>-1, 1, 0</Text>
            </Hexagon>
            <Hexagon q={-1} r={0} s={1} />
            <Hexagon q={-2} r={0} s={1} />
            <Path start={new Hex(0, 0, 0)} end={new Hex(-2, 0, 1)} />
          </Layout>
          <Pattern id="pat-1" link="https://placekitten.com/250/250" />
          <Pattern id="pat-2" link="https://placekitten.com/300/300" />
        </HexGrid>
      </div>
    );
  }
}

Examples

Coming soon.

Package Sidebar

Install

npm i kitty-hexgrid

Weekly Downloads

3

Version

1.2.9

License

MIT

Unpacked Size

63.4 kB

Total Files

15

Last publish

Collaborators

  • gokhanmelma