Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SVG height is 684? #35

Open
erodewald opened this issue Apr 5, 2019 · 4 comments
Open

SVG height is 684? #35

erodewald opened this issue Apr 5, 2019 · 4 comments

Comments

@erodewald
Copy link

I'm not sure what's going on, but I have generated several patterns and they always resolve to the SVG height being 684 with a width of 100.

const pattern = GeoPattern.generate("d2040d8d-a0b2-40a3-9f48-db61f09cb47c")
console.log(pattern.toDataUri())
Output

data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" width="100" height="684"><rect x="0" y="0" width="100%" height="100%" fill="rgb(240,101,36)"></rect><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.02" stroke-width="19px" transform="translate(-25,-135)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.02" stroke-width="19px" transform="translate(-25,549)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.13266666666666665" stroke-width="19px" transform="translate(-25,-116)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.13266666666666665" stroke-width="19px" transform="translate(-25,568)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.098" stroke-width="19px" transform="translate(-25,-97)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.098" stroke-width="19px" transform="translate(-25,587)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.08066666666666666" stroke-width="19px" transform="translate(-25,-78)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.08066666666666666" stroke-width="19px" transform="translate(-25,606)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.098" stroke-width="19px" transform="translate(-25,-59)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.098" stroke-width="19px" transform="translate(-25,625)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.046" stroke-width="19px" transform="translate(-25,-40)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.046" stroke-width="19px" transform="translate(-25,644)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.05466666666666667" stroke-width="19px" transform="translate(-25,-21)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.05466666666666667" stroke-width="19px" transform="translate(-25,663)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.02" stroke-width="19px" transform="translate(-25,-2)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.02" stroke-width="19px" transform="translate(-25,682)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.08066666666666666" stroke-width="19px" transform="translate(-25,17)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.08066666666666666" stroke-width="19px" transform="translate(-25,701)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.10666666666666667" stroke-width="19px" transform="translate(-25,36)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.10666666666666667" stroke-width="19px" transform="translate(-25,720)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.10666666666666667" stroke-width="19px" transform="translate(-25,55)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.10666666666666667" stroke-width="19px" transform="translate(-25,739)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.11533333333333334" stroke-width="19px" transform="translate(-25,74)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.11533333333333334" stroke-width="19px" transform="translate(-25,758)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.13266666666666665" stroke-width="19px" transform="translate(-25,93)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.13266666666666665" stroke-width="19px" transform="translate(-25,777)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.12400000000000001" stroke-width="19px" transform="translate(-25,112)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.12400000000000001" stroke-width="19px" transform="translate(-25,796)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.08066666666666666" stroke-width="19px" transform="translate(-25,131)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.08066666666666666" stroke-width="19px" transform="translate(-25,815)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.14133333333333334" stroke-width="19px" transform="translate(-25,150)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.14133333333333334" stroke-width="19px" transform="translate(-25,834)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.08933333333333333" stroke-width="19px" transform="translate(-25,169)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.08933333333333333" stroke-width="19px" transform="translate(-25,853)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.13266666666666665" stroke-width="19px" transform="translate(-25,188)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.13266666666666665" stroke-width="19px" transform="translate(-25,872)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.046" stroke-width="19px" transform="translate(-25,207)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.046" stroke-width="19px" transform="translate(-25,891)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.10666666666666667" stroke-width="19px" transform="translate(-25,226)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.10666666666666667" stroke-width="19px" transform="translate(-25,910)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.05466666666666667" stroke-width="19px" transform="translate(-25,245)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.05466666666666667" stroke-width="19px" transform="translate(-25,929)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.046" stroke-width="19px" transform="translate(-25,264)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.046" stroke-width="19px" transform="translate(-25,948)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.08933333333333333" stroke-width="19px" transform="translate(-25,283)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.08933333333333333" stroke-width="19px" transform="translate(-25,967)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.08066666666666666" stroke-width="19px" transform="translate(-25,302)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.08066666666666666" stroke-width="19px" transform="translate(-25,986)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.02" stroke-width="19px" transform="translate(-25,321)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.02" stroke-width="19px" transform="translate(-25,1005)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.11533333333333334" stroke-width="19px" transform="translate(-25,340)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.11533333333333334" stroke-width="19px" transform="translate(-25,1024)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.06333333333333334" stroke-width="19px" transform="translate(-25,359)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.06333333333333334" stroke-width="19px" transform="translate(-25,1043)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.13266666666666665" stroke-width="19px" transform="translate(-25,378)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.13266666666666665" stroke-width="19px" transform="translate(-25,1062)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.08933333333333333" stroke-width="19px" transform="translate(-25,397)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.08933333333333333" stroke-width="19px" transform="translate(-25,1081)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.028666666666666667" stroke-width="19px" transform="translate(-25,416)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.028666666666666667" stroke-width="19px" transform="translate(-25,1100)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.15" stroke-width="19px" transform="translate(-25,435)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.15" stroke-width="19px" transform="translate(-25,1119)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.03733333333333333" stroke-width="19px" transform="translate(-25,454)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.03733333333333333" stroke-width="19px" transform="translate(-25,1138)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.11533333333333334" stroke-width="19px" transform="translate(-25,473)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.11533333333333334" stroke-width="19px" transform="translate(-25,1157)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.15" stroke-width="19px" transform="translate(-25,492)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.15" stroke-width="19px" transform="translate(-25,1176)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.03733333333333333" stroke-width="19px" transform="translate(-25,511)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#ddd" opacity="0.03733333333333333" stroke-width="19px" transform="translate(-25,1195)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.098" stroke-width="19px" transform="translate(-25,530)"></path><path d="M0 90 C 17.5 0, 32.5 0, 50 90 S 82.5 180, 100 90 S 132.5 0, 150, 90" fill="none" stroke="#222" opacity="0.098" stroke-width="19px" transform="translate(-25,1214)"></path></svg>

Paste the output into your browser location bar – you'll see that it's 100x684. What's going on here?

I'd expect it to at least return 100x100, maybe with an option of supplying my own height & width to better define the tile pattern.

@btmills
Copy link
Owner

btmills commented Apr 29, 2019

Each pattern determines its own dimensions based on what will tile (example), and those should be changing based on each input string. Can you provide a few more examples of input strings that all produce tiles with the same dimensions so I can see what's going on?

@erodewald
Copy link
Author

Ahhh. Well, I am using UUIDs to generate unique backgrounds for my users (e.g., f6c2a60f-716c-4ac5-b567-39195bf9c073). Because of my design constraints, I wasn't able to affect the "stretch" of my background at all so when I got a very narrow and tall tile from a UUID, it has a negative impact on my layout.

So I don't think the problem is that some tiles are tall and skinny – it's that I cannot enforce aspect ratio or arbitrary height/widths in the generated SVG (although I explicitly use the base64 data). If the SVG "viewport" can be simply cut-off at any height or width prior to generating the base64 data, the tiling remains in tact and I don't end up with weird design issues.

@btmills
Copy link
Owner

btmills commented Apr 30, 2019

Are you able to put together a codesandbox that demonstrates the issue it’s causing with your layout? This was built with browser background tiling in mind, so I’m not surprised it’s hard to use in places that affect layout. If you’re not able to let it tile or adjust the dimensions or overflow somehow, I believe a library like Trianglify would give you abstract backgrounds for known dimensions.

@erodewald
Copy link
Author

I might be able to put something together. I can't go into great detail but the use case constraints come from it being a webview within a mobile app where the style guidelines in place are quite strict. It might be tough for me to get those image style rules changed.

I don't want to ask you to bastardize your library on my behalf, I'll check out Trianglify in the meantime.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants