PHPackages                             roelvanduijnhoven/reverse-image-cover - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Image &amp; Media](/categories/media)
4. /
5. roelvanduijnhoven/reverse-image-cover

Abandoned → [jouwweb/reverse-image-cover](/?search=jouwweb%2Freverse-image-cover)ArchivedLibrary[Image &amp; Media](/categories/media)

roelvanduijnhoven/reverse-image-cover
=====================================

Compute visible part of source image when covered in viewport

0.3.1(7y ago)01.2kMITPHPPHP &gt;=5.4

Since Aug 12Pushed 7y ago2 watchersCompare

[ Source](https://github.com/JouwWeb/reverse-image-cover)[ Packagist](https://packagist.org/packages/roelvanduijnhoven/reverse-image-cover)[ RSS](/packages/roelvanduijnhoven-reverse-image-cover/feed)WikiDiscussions master Synced today

READMEChangelog (5)Dependencies (1)Versions (5)Used By (0)

Reverse Image Cover
===================

[](#reverse-image-cover)

Small library that can compute the part of the source image that is shown when it is being projected onto an element as background.

Can be used for example to reduce bandwidth by preprocessing the image so that only the crop is returned. The end result will be identical to the viewer.

Currently only supports backgrounds that *cover* the image and use percentages to position the image.

Usage
-----

[](#usage)

```
$viewport = new BackgroundCoverViewport(
  $viewportWidth,
  $viewportHeigt,
  $backgroundPositionX,
  $backgroundPositionY
);

$crop = $viewport->computeUsedCrop(
  $imageWidth,
  $imageHeight
);

echo "Visible part of image starts at({$crop[0]}, {$crop[1]}) ";
echo "and has a dimension of {$crop[2]} x {$crop[3]}";
```

Tests
-----

[](#tests)

Tests can be ran by:

1. `composer install`
2. `vendor/bin/phpunit`

The test suite can be visualized as follows:

1. Run server `php -S localhost:8080`
2. Visit [http://localhost:8080/tests/demo.php`](http://localhost:8080/tests/demo.php%60)

###  Health Score

26

—

LowBetter than 41% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity14

Limited adoption so far

Community8

Small or concentrated contributor base

Maturity51

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~454 days

Total

4

Last Release

2617d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/ca21233cea84cc055bcc3678608a64bcf30b3da970a5fab96f54590ae3506125?d=identicon)[roelvanduijnhoven](/maintainers/roelvanduijnhoven)

---

Top Contributors

[![villermen](https://avatars.githubusercontent.com/u/1106303?v=4)](https://github.com/villermen "villermen (1 commits)")

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/roelvanduijnhoven-reverse-image-cover/health.svg)

```
[![Health](https://phpackages.com/badges/roelvanduijnhoven-reverse-image-cover/health.svg)](https://phpackages.com/packages/roelvanduijnhoven-reverse-image-cover)
```

###  Alternatives

[goat1000/svggraph

Generates SVG graphs

135911.1k3](/packages/goat1000-svggraph)[gravatarphp/gravatar

Gravatar URL builder which is most commonly called as a Gravatar library

16653.6k2](/packages/gravatarphp-gravatar)[rsoury/wp-imgix

Rewrites WordPress image URLs to use ImgIX

167.2k](/packages/rsoury-wp-imgix)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
