Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/albinotonnina/dom-to-points
Generate a polyline string
https://github.com/albinotonnina/dom-to-points
Last synced: 13 days ago
JSON representation
Generate a polyline string
- Host: GitHub
- URL: https://github.com/albinotonnina/dom-to-points
- Owner: albinotonnina
- Created: 2018-05-17T16:29:15.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2022-12-08T18:57:37.000Z (about 2 years ago)
- Last Synced: 2025-01-15T22:33:14.727Z (about 1 month ago)
- Language: JavaScript
- Size: 1.37 MB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 23
-
Metadata Files:
- Readme: Readme.md
Awesome Lists containing this project
README
# dom-to-point
[data:image/s3,"s3://crabby-images/ae0d1/ae0d1f7b0b4211a9bdd397de62744271ca10322f" alt="Codacy Badge"](https://app.codacy.com/app/albinotonnina/dom-to-points?utm_source=github.com&utm_medium=referral&utm_content=albinotonnina/dom-to-points&utm_campaign=badger)
[data:image/s3,"s3://crabby-images/71b4e/71b4edf1644eb4b4684227d8b24074ace774ed6c" alt="Build Status"](https://travis-ci.org/albinotonnina/dom-to-points)
[data:image/s3,"s3://crabby-images/31e5f/31e5f211fb7d0286e77b5fc7514d67f037de6684" alt="Greenkeeper badge"](https://greenkeeper.io/)
[data:image/s3,"s3://crabby-images/6e771/6e77129a68935ab150842181e88993d5483a28cb" alt="codecov"](https://codecov.io/gh/albinotonnina/dom-to-points)## Q:What is this thing solving?
If you want to get an SVG like the red thing below
data:image/s3,"s3://crabby-images/914d2/914d204790996faabc9901029770ca8549f00f49" alt=""
## Install
```
yarn add dom-to-points // Package size: 795 B
```## Usage
```javascript
import {getPolygonString} from 'dom-to-points'
// or const {getPointsArray, getPolygonString} = require('dom-to-points')const points = getPolygonString('.item')
// or const points = getPolygonString([...document.querySelectorAll('.item')])console.log('polygonString', points)
/*
0,0 300,0 300,100 0,100 0,100 200,100 200,200 0,200 0,200 200,200 200,300 0,300 0,300 300,300 300,400 0,400 0,400 0,300 0,300 0,200 0,200 0,100 0,100 0,0
*/
``````javascript
const points = getPointsArray('.item')
// or const points = getPointsArray([...document.querySelectorAll('.item')])console.log('points', points)
/*
[
[ 0, 0 ],
[ 300, 0 ],
[ 300, 100 ],
[ 0, 100 ],
[ 0, 100 ],
[ 200, 100 ],
[ 200, 200 ],
[ 0, 200 ],
[ 0, 200 ],
[ 200, 200 ],
[ 200, 300 ],
[ 0, 300 ],
[ 0, 300 ],
[ 300, 300 ],
[ 300, 400 ],
[ 0, 400 ],
[ 0, 400 ],
[ 0, 300 ],
[ 0, 300 ],
[ 0, 200 ],
[ 0, 200 ],
[ 0, 100 ],
[ 0, 100 ],
[ 0, 0 ]
]
*/
```## Q: What then?
You could make a polygon with the data and add it to an SVG.
You could use a library, such as [SVG.js](http://svgjs.com/elements/#polyline-constructor) or [paper.js](http://paperjs.org)
Check this [jsfiddle demo](https://jsfiddle.net/albinotonnina/paoqv2c3/).
## Maintainers
[@albinotonnina](https://github.com/albinotonnina)
## Contribute
PRs accepted.
## License
MIT © 2018 Albino Tonnina