Skip to content

A flexible directive to render a source image into a circle and intelligently size it to avoid and distortion of the image often caused by dimension mismatches.

License

Notifications You must be signed in to change notification settings

anied/angular-circle-img

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

60 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Angular Circle Img (angular-circle-img)

Description

Angular Circle Image is intended to be a flexible directive to render a source image into a circle and intelligently size it to avoid and distortion of the image often caused by dimension mismatches. It is currently under development and has not yet reached a major version release.

Basic Usage

Installation

Angular Circle Image can be installed using bower:

$ bower install angular-circle-img --save

Including The Directive In Your Project

To use Angular Circle Image you must add the dist directory into your project and include the code in your page:

<script src="dist/angularCircleImg.min.js"></script>

Then include "angularCircleImgModule" as a dependency for your application module:

angular.module('yourModule', ['angularCircleImgModule']);

Using the Directive

The directive is used as the <circle-img> element, with options passed in by attribute.

<circle-img ci-src="img/VanGogh.jpg" ci-diameter="57" ci-alt="Image of Van Gogh"></circle-img>

For simplicity's sake, no css dependency is included with this package. To make your CIs (Circle Images) behave more like standard images, add the following style somewhere in your CSS:

.ci-wrapper {
    display: inline-block;
    vertical-align: middle;
}

See the "examples" page in the repo to see the directive in action.

Dev environment

Install npm and bower dependencies. Run the persistent tasks npm start and gulp develop:debug in two separate terminal windows, and then navigate to localhost:8000 -- this will load the "examples" page.

Settings (Attributes)

Please note that all attributes are "@" scoped.

  • ci-src: Source path to your image-- will be passed to the resulting <img> element's ng-src attribute.
  • ci-diameter: Number representing the desired diameter of the resulting circle-- image size will be adjusted so that the smallest dimension of the image is equal to this diameter and the other dimension is sized appropriately
  • ci-alt: Text for the image alt attribute.
  • ci-balance-x [optional: "left", "center", "right"]: If included, shows preference to the left edge, center, or right edge of the image when the width is the larger dimension. Default to "center" when omitted.
  • ci-balance-y [optional: "top", "center", "bottom"]: If included, shows preference to the top edge, center, or bottom edge of the image when the height is the larger dimension. Default to "center" when omitted.
  • ci-class [optional] String of space delineated class names you would like to add to the wrapper div portion of the circle-img markup.

How It Works

Natural image size can only be measured in the DOM-- as such, the directive code appends the image (hidden with positioning and opacity) to the DOM to ascertain its natural dimensions, and uses those dimensions to calculate how to fit the image into a circle. The image is then removed from the DOM. There are no benchmarks yet as to the performance of this approach, so it may be wise to do some testing if you intend to use this on many elements on a given page or application.

TODO List

  • Get the app shell setup
    • Express server up and running for development
    • Bower & Example/Dev Page
    • Gulp tasks to build src into example and dist
  • Build the directive (DUMB)
    • Get the directive available in the example/dev environment
    • Build it to work as designed
  • Polish (SMART)
    • Figure out the best way to package and expose
      • Standard module?
      • Browserify?
      • ES6?
      • Something else?
  • Flesh out documentation to be more complete/readable
  • Refactor to leverage more ES6 features
  • Nicen up example page for easier public consumption.
  • Tests?

About

A flexible directive to render a source image into a circle and intelligently size it to avoid and distortion of the image often caused by dimension mismatches.

Resources

License

Stars

Watchers

Forks

Packages

No packages published