Home | History | Annotate | only in /external/subsampling-scale-image-view
Up to higher level directory
NameDateSize
.travis.yml21-Aug-2018488
build.gradle21-Aug-2018381
CONTRIBUTING.md21-Aug-2018945
docs/21-Aug-2018
gradle/21-Aug-2018
gradle.properties21-Aug-2018730
gradlew21-Aug-20185.2K
gradlew.bat21-Aug-20182.2K
library/21-Aug-2018
LICENSE21-Aug-201810K
README.md21-Aug-20185.8K
release.gradle21-Aug-20182.3K
sample/21-Aug-2018
settings.gradle21-Aug-201837

README.md

      1 Subsampling Scale Image View
      2 ===========================
      3 
      4 [![Build Status](https://travis-ci.org/davemorrissey/subsampling-scale-image-view.svg?branch=master)](https://travis-ci.org/davemorrissey/subsampling-scale-image-view)
      5 
      6 A custom image view for Android, designed for photo galleries and displaying huge images (e.g. maps and building plans) without `OutOfMemoryError`s. Includes pinch to zoom, panning, rotation and animation support, and allows easy extension so you can add your own overlays and touch event detection.
      7 
      8 The view optionally uses subsampling and tiles to support very large images - a low resolution base layer is loaded and as you zoom in, it is overlaid with smaller high resolution tiles for the visible area. This avoids holding too much data in memory. It's ideal for displaying large images while allowing you to zoom in to the high resolution details. You can disable tiling for smaller images and when displaying a bitmap object. There are some advantages and disadvantages to disabling tiling so to decide which is best, see [the wiki](https://github.com/davemorrissey/subsampling-scale-image-view/wiki/02.-Displaying-images).
      9 
     10 #### Guides
     11 
     12 * [Releases & downloads](https://github.com/davemorrissey/subsampling-scale-image-view/releases)
     13 * [Installation and setup](https://github.com/davemorrissey/subsampling-scale-image-view/wiki/01.-Setup)
     14 * [Image display notes & limitations](https://github.com/davemorrissey/subsampling-scale-image-view/wiki/02.-Displaying-images)
     15 * [Using preview images](https://github.com/davemorrissey/subsampling-scale-image-view/wiki/03.-Preview-images)
     16 * [Handling orientation changes](https://github.com/davemorrissey/subsampling-scale-image-view/wiki/05.-Orientation-changes)
     17 * [Advanced configuration](https://github.com/davemorrissey/subsampling-scale-image-view/wiki/07.-Configuration)
     18 * [Event handling](https://github.com/davemorrissey/subsampling-scale-image-view/wiki/09.-Events)
     19 * [Animation](https://github.com/davemorrissey/subsampling-scale-image-view/wiki/08.-Animation)
     20 * [Extension](https://github.com/davemorrissey/subsampling-scale-image-view/wiki/10.-Extension)
     21 * [Reference (JavaDocs)](http://davemorrissey.github.io/subsampling-scale-image-view/javadoc/)
     22 
     23 #### Migration guides
     24 
     25 Versions 3.9.0, 3.8.0 and 3.0.0 contain breaking changes. Migration instructions can be found [in the wiki](https://github.com/davemorrissey/subsampling-scale-image-view/wiki/X.--Migration-guides).
     26 
     27 #### Download the sample app
     28 
     29 [![Get it on Google Play](docs/images/google_play.png)](https://play.google.com/store/apps/details?id=com.davemorrissey.labs.subscaleview.sample)
     30 
     31 [Kotlin Sample App on GitHub](https://github.com/davemorrissey/ssiv-kotlin-sample)
     32 
     33 #### Demo
     34 
     35 ![Demo](docs/images/demo.gif)
     36 
     37 ## Features
     38 
     39 #### Image display
     40 
     41 * Display images from assets, resources, the file system or bitmaps
     42 * Automatically rotate images from the file system (e.g. the camera or gallery) according to EXIF
     43 * Manually rotate images in 90 increments
     44 * Display a region of the source image
     45 * Use a preview image while large images load
     46 * Swap images at runtime
     47 * Use a custom bitmap decoder
     48 
     49 *With tiling enabled:*
     50 
     51 * Display huge images, larger than can be loaded into memory
     52 * Show high resolution detail on zooming in
     53 * Tested up to 20,000x20,000px, though larger images are slower
     54 
     55 #### Gesture detection
     56 
     57 * One finger pan
     58 * Two finger pinch to zoom
     59 * Quick scale (one finger zoom)
     60 * Pan while zooming
     61 * Seamless switch between pan and zoom
     62 * Fling momentum after panning
     63 * Double tap to zoom in and out
     64 * Options to disable pan and/or zoom gestures
     65 
     66 #### Animation
     67 
     68 * Public methods for animating the scale and center
     69 * Customisable duration and easing
     70 * Optional uninterruptible animations
     71 
     72 #### Overridable event detection
     73 * Supports `OnClickListener` and `OnLongClickListener`
     74 * Supports interception of events using `GestureDetector` and `OnTouchListener`
     75 * Extend to add your own gestures
     76 
     77 #### Easy integration
     78 * Use within a `ViewPager` to create a photo gallery
     79 * Easily restore scale, center and orientation after screen rotation
     80 * Can be extended to add overlay graphics that move and scale with the image
     81 * Handles view resizing and `wrap_content` layout
     82 
     83 ## Quick start
     84 
     85 **1)** Add `com.davemorrissey.labs:subsampling-scale-image-view:3.9.0` as a dependency in your build.gradle file.
     86 
     87 **2)** Add the view to your layout XML.
     88 
     89     <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
     90         android:layout_width="match_parent"
     91         android:layout_height="match_parent" >
     92 
     93         <com.davemorrissey.labs.subscaleview.SubsamplingScaleImageView
     94             android:id="@+id/imageView"
     95             android:layout_width="match_parent"
     96             android:layout_height="match_parent"/>
     97 
     98     </LinearLayout>
     99 
    100 **3a)** Now, in your fragment or activity, set the image resource, asset name or file path.
    101 
    102     SubsamplingScaleImageView imageView = (SubsamplingScaleImageView)findViewById(id.imageView);
    103     imageView.setImage(ImageSource.resource(R.drawable.monkey));
    104     // ... or ...
    105     imageView.setImage(ImageSource.asset("map.png"))
    106     // ... or ...
    107     imageView.setImage(ImageSource.uri("/sdcard/DCIM/DSCM00123.JPG"));
    108 
    109 **3b)** Or, if you have a `Bitmap` object in memory, load it into the view. This is unsuitable for large images because it bypasses subsampling - you may get an `OutOfMemoryError`.
    110 
    111     SubsamplingScaleImageView imageView = (SubsamplingScaleImageView)findViewById(id.imageView);
    112     imageView.setImage(ImageSource.bitmap(bitmap));
    113 
    114 ## Photo credits
    115 
    116 * San Martino by Luca Bravo, via [unsplash.com](https://unsplash.com/photos/lWAOc0UuJ-A)
    117 * Swiss Road by Ludovic Fremondiere, via [unsplash.com](https://unsplash.com/photos/3XN-BNRDUyY)
    118 
    119 ## About
    120 
    121 Copyright 2018 David Morrissey, and licensed under the Apache License, Version 2.0. No attribution is necessary but it's very much appreciated. Star this project if you like it!
    122