GithubHelp home page GithubHelp logo

shapedimageview's Introduction

ShapedImageView

Android CI

  • Support circle & round rect shaped
  • Support stroke
  • Support TransitionDrawable
  • New Support custom PathExtension

Screenshots

Demo Preview PathExtension Preview

Usage

dependencies

Step 1. Add the JitPack repository to your build file

allprojects {
    repositories {
        ...
        maven { url 'https://jitpack.io' }
    }
}

Step 2. Add the dependency

dependencies {
    implementation 'cn.gavinliu:ShapedImageView:0.8.7'
}

Circle

<cn.gavinliu.android.lib.shapedimageview.ShapedImageView
    ...
    app:shape_mode="circle"

    app:stroke_color="#009688"
    app:stroke_width="3dp" />

Round Rect

<cn.gavinliu.android.lib.shapedimageview.ShapedImageView
    ...
    app:shape_mode="round_rect"
    app:round_radius="20dp"

    app:stroke_color="#009688"
    app:stroke_width="3dp" />

PathExtension

image1.setExtension(new CDPathExtension());

class CDPathExtension implements ShapedImageView.PathExtension {

    @Override
    public void onLayout(Path path, int width, int height) {
        path.reset();
        path.addCircle(width / 2, height / 2, width / 8, Path.Direction.CW);
    }
}

Programmatically

public void setShape(int shapeMode, float radius);

public void setShapeMode(int shapeMode); // SHAPE_MODE_ROUND_RECT | SHAPE_MODE_CIRCLE

public void setShapeRadius(float radius);

public void setStroke(int strokeColor, float strokeWidth);

public void setStrokeColor(int strokeColor);

public void setStrokeWidth(float strokeWidth);

TODO

  • Support Any Shape (SVG to PathShape)

License

The MIT License

Copyright (c) 2016-present, GavinLiu

shapedimageview's People

Contributors

gavinliu avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

shapedimageview's Issues

display incorrectly with round_rect mode.

ShapedImageView's bottom-right and bottom-left corner display incorrectly with below setting.

<cn.gavinliu.android.lib.shapedimageview.ShapedImageView
      ...
       app:round_radius="5dp"
       app:shape_mode="round_rect"
       app:stroke_color="@color/black_color"
       app:stroke_width="1dp" />

setStroke 方法是不是有Bug

public void setStroke(int strokeColor, float strokeWidth) {
        if (mStrokeWidth <= 0) return;

        if (mStrokeWidth != strokeWidth) {
            mStrokeWidth = strokeWidth;

            int width = getMeasuredWidth();
            int height = getMeasuredHeight();
            mStrokeShape.resize(width - mStrokeWidth * 2, height - mStrokeWidth * 2);

            postInvalidate();
        }

        if (mStrokeColor != strokeColor) {
            mStrokeColor = strokeColor;

            makeStrokeBitmap();
            postInvalidate();
        }
    }

if (strokeWidth <= 0) return; 是否应该改成,否则无法通过直接代码设置storke width。

Glide removes stroke

Loading an image with Glide into ShapedImageView seems to remove the stroke.

Glide.with(context)
                    .load(user.image)
                    .centerCrop()
                    .diskCacheStrategy(DiskCacheStrategy.SOURCE)
                    .into(pictureImageView)

NullPointerException:invoke virtual method 'boolean android.graphics.Bitmap.isRecycled()

Sometimes I get crash report from Crashlytics.

Fatal Exception: java.lang.NullPointerException: Attempt to invoke virtual method 'boolean android.graphics.Bitmap.isRecycled()' on a null object reference
       at android.graphics.BaseCanvas.throwIfCannotDraw(BaseCanvas.java:69)
       at android.view.DisplayListCanvas.throwIfCannotDraw(DisplayListCanvas.java:226)
       at android.view.RecordingCanvas.drawBitmap(RecordingCanvas.java:82)
       at cn.gavinliu.android.lib.shapedimageview.ShapedImageView.onDraw(ShapedImageView.java:130)
       at android.view.View.draw(View.java:21860)
       at android.view.View.updateDisplayListIfDirty(View.java:20733)
       at android.view.View.draw(View.java:21586)
       at android.view.ViewGroup.drawChild(ViewGroup.java:4551)
       at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4326)
       at android.view.View.draw(View.java:21863)
       at android.view.View.updateDisplayListIfDirty(View.java:20733)
       at android.view.View.draw(View.java:21586)
       at android.view.ViewGroup.drawChild(ViewGroup.java:4551)
       at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4326)
       at android.view.View.updateDisplayListIfDirty(View.java:20719)
       at android.view.View.draw(View.java:21586)
       at android.view.ViewGroup.drawChild(ViewGroup.java:4551)
       at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4326)
       at android.view.View.draw(View.java:21863)
       at android.view.View.updateDisplayListIfDirty(View.java:20733)
       at android.view.View.draw(View.java:21586)
       at android.view.ViewGroup.drawChild(ViewGroup.java:4551)
       at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4326)
       at android.view.View.updateDisplayListIfDirty(View.java:20719)
       at android.view.View.draw(View.java:21586)
       at android.view.ViewGroup.drawChild(ViewGroup.java:4551)
       at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4326)
       at android.view.View.draw(View.java:21863)
       at android.view.View.updateDisplayListIfDirty(View.java:20733)
       at android.view.View.draw(View.java:21586)
       at android.view.ViewGroup.drawChild(ViewGroup.java:4551)
       at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4326)
       at android.view.View.updateDisplayListIfDirty(View.java:20719)
       at android.view.View.draw(View.java:21586)
       at android.view.ViewGroup.drawChild(ViewGroup.java:4551)
       at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4326)
       at android.view.View.updateDisplayListIfDirty(View.java:20719)
       at android.view.View.draw(View.java:21586)
       at android.view.ViewGroup.drawChild(ViewGroup.java:4551)
       at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4326)
       at android.view.View.updateDisplayListIfDirty(View.java:20719)
       at android.view.View.draw(View.java:21586)
       at android.view.ViewGroup.drawChild(ViewGroup.java:4551)
       at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4326)
       at android.view.View.updateDisplayListIfDirty(View.java:20719)
       at android.view.View.draw(View.java:21586)
       at android.view.ViewGroup.drawChild(ViewGroup.java:4551)
       at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4326)
       at android.view.View.draw(View.java:21863)
       at com.android.internal.policy.DecorView.draw(DecorView.java:1083)
       at android.view.View.updateDisplayListIfDirty(View.java:20733)
       at android.view.ThreadedRenderer.updateViewTreeDisplayList(ThreadedRenderer.java:725)
       at android.view.ThreadedRenderer.updateRootDisplayList(ThreadedRenderer.java:731)
       at android.view.ThreadedRenderer.draw(ThreadedRenderer.java:840)
       at android.view.ViewRootImpl.draw(ViewRootImpl.java:3932)
       at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:3706)
       at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:3014)
       at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1873)
       at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:8478)
       at android.view.Choreographer$CallbackRecord.run(Choreographer.java:949)
       at android.view.Choreographer.doCallbacks(Choreographer.java:761)
       at android.view.Choreographer.doFrame(Choreographer.java:696)
       at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:935)
       at android.os.Handler.handleCallback(Handler.java:873)
       at android.os.Handler.dispatchMessage(Handler.java:99)
       at android.os.Looper.loop(Looper.java:214)
       at android.app.ActivityThread.main(ActivityThread.java:6986)
       at java.lang.reflect.Method.invoke(Method.java)
       at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:494)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1445)

AndroidManifest.xml 文件冲突

AndroidManifest.xml 里的 android:allowBackup属性设置的为false,我应用里设置的为true,通过gradle导入运行不了提示冲突

Manifest Merger Failed

Hello, when importing your library into my application, I get the following error:

Error:Execution failed for task ':app:processDebugManifest'.
Manifest merger failed : Attribute application@allowBackup value=(true) from AndroidManifest.xml:21:9-35
is also present at [cn.gavinliu.android.lib:ShapedImageView:0.8.4] AndroidManifest.xml:12:9-36 value=(false).
Suggestion: add 'tools:replace="android:allowBackup"' to element at AndroidManifest.xml:20:5-118:19 to override.

This is from the AndroidManifest.xml in your library have a android:allowBackup, android:supportRtl, and an android:label attributes.

These attributes should be removed so that this error goes away.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.