Avatar View


Source link: https://github.com/TangoAgency/avatar-view

Avatar View

Avatar View library was implemented based on Matt Precious's Don’t Fear the Canvas lecture. I decided to create this library in order to achieve an ImageView which can smoothly display user's profile image or his username/name initial letter (in the case when the image was not provided).

Please take a look at the examples below:

Simple library presentation ExampleActivity & BindingsExample

Usage

This library can be used in two ways: using standard Android methods and using Android Data Binding.

###Standard:

Step 1

Add gradle dependency:

dependencies {

  compile 'agency.tango.android:avatar-view:{
latest_release
}
'

//if you want to use Picasso for loading images
  compile 'agency.tango.android:avatar-view-picasso:{
latest_release
}
'

//if you want to use Glide for loading images
  compile 'agency.tango.android:avatar-view-glide:{
latest_release
}
' 
}

Step 2

Add to your xml layout file:

<agency.tango.android.avatarview.views.AvatarView
  android:layout_width="100dp"
  android:layout_height="100dp"
  app:av_border_color="@android:color/white"
  app:av_border_width="4dp"
  app:av_text_size_percentage="35" />

Step 3

Add to your activity:

 AvatarView avatarView;
  IImageLoader imageLoader;

@Override
  protected void onCreate(@Nullable Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

 avatarView = (AvatarView) findViewById(R.id.avatar_view_example);

 imageLoader = new PicassoLoader();

imageLoader.loadImage(avatarView, "http:/example.com/user/someUserAvatar.png", "User Name");

  
}

If you want to use a different library than Picasso for loading images you have to create a loader which extends ImageLoaderBase class. Basically, you have to override one method. Take a look how I have done it in PicassoLoader available in the avatar-view-picasso module.

ImageLoaderBase has two constructors: one with no parameters and second one where you can pass String placeholder in order to change the default "-". You can also set it directly in AvatarPlaceholder constructor. More info about AvatarPlaceholder here.

###Data Binding:

Step 1

Add gradle dependency:

dependencies {

  compile 'agency.tango.android:avatar-view:{
latest_release
}
'
  compile 'agency.tango.android:avatar-view-bindings:{
latest_release
}
'

//if you want to use Picasso for loading images
  compile 'agency.tango.android:avatar-view-picasso:{
latest_release
}
'

//if you want to use Glide for loading images
  compile 'agency.tango.android:avatar-view-glide:{
latest_release
}
' 
}

Step 2

I will show how to edit your xml file based on User class. Let's see:

<data>
  <variable

name="user"

type="User" /> </data>  <agency.tango.android.avatarview.views.AvatarView
  android:layout_width="100dp"
  android:layout_height="100dp"
  bind:av_border_color="@android:color/white"
  bind:av_border_width="6dp"
  bind:av_text_size_percentage="40"
  bind:avatarUrl="@{
user.avatarUrl
}
"
  bind:name="@{
user.name
}
" />

Step 3

Add to your activity:

private ExampleActivityBinding binding;  @Override protected void onCreate(@Nullable Bundle savedInstanceState) {

  super.onCreate(savedInstanceState);

binding = DataBindingUtil.setContentView(this, R.layout.example_activity, new ExampleDataComponent());

  binding.setUser(new User("User Name", "http:/example.com/user/someUserAvatar.png"));
 
}
  private static class ExampleDataComponent implements DataBindingComponent {

  public AvatarViewBindings getAvatarViewBindings() {

return new AvatarViewBindings(new PicassoLoader());

  
}
 
}

Take a look at AvatarViewBindings class where BindingsAdapter is configured ( bind:avatarUrl and bind:name for usage in XML). In order to correctly use AvatarViewBindings you have to create class extending DataBindingComponent and pass it as a third parameter in DataBindingUtil.setContentView() method. This is obligatory because AvatarViewBindings takes an IImageLoader parameter in it's constructor. You can find more information about this topic in Deep dive into Android Data Binding talk.

I have explained PicassoLoader issue in step 3 in Standard Method part.

####AvatarPlaceholder

AvatarPlaceholder is a Drawable which is set as a AvatarView background when the image hasn't been loaded yet. It is a letter on a one-color background (just like in ex. Google, Youtube avatars). Default placeholder String (displayed when the username is null or empty) is "-". TextSizePercentage value sets how big part of the view is taken by the text. Default textSizePercentage is 33. You can change those values by passing another ones in AvatarPlaceholder constructor or not directly by using IImageLoader class methods/constructors.

####Additional information

  • Avatar background color is calculated using hashCode() method called on a given name String.
  • Default border width is 2dp and default border color is white.
  • Placeholder letters are currently always white (in future user will be able to choose a different color).
  • It is recommended to set your default placeholder String as short as possible (the best would be one letter).

Getting Help

To report a specific problem or feature request, open a new issue on Github.

Company

           

Here you can see open source work developed by Tango Agency.

Whether you're searching for a new partner or trusted team for creating your new great product we are always ready to start work with you.

You can contact us via [email protected]. Thanks in advance.

Resources

Android Block style Button.

BlockButton is an extension of LinearLayout (thinking of extending RelativeLayout too..) hence, orientation should be set.

A tool to analysis Android/Java project dependencies.

DroidBot is a lightweight test input generator for Android.

It can send random or scripted input events to an Android app, achieve higher test coverage more quickly, and generate a UI transition graph (UTG) after testing.

A wonderful library to display 2D fancy carousels for Android.

A library of classes to create every kind of gauges.

A library used to make good looking curved SeekBar.

Topics


2D Engines   3D Engines   9-Patch   Action Bars   Activities   ADB   Advertisements   Analytics   Animations   ANR   AOP   API   APK   APT   Architecture   Audio   Autocomplete   Background Processing   Backward Compatibility   Badges   Bar Codes   Benchmarking   Bitmaps   Bluetooth   Blur Effects   Bread Crumbs   BRMS   Browser Extensions   Build Systems   Bundles   Buttons   Caching   Camera   Canvas   Cards   Carousels   Changelog   Checkboxes   Cloud Storages   Color Analysis   Color Pickers   Colors   Comet/Push   Compass Sensors   Conferences   Content Providers   Continuous Integration   Crash Reports   Credit Cards   Credits   CSV   Curl/Flip   Data Binding   Data Generators   Data Structures   Database   Database Browsers   Date &   Debugging   Decompilers   Deep Links   Dependency Injections   Design   Design Patterns   Dex   Dialogs   Distributed Computing   Distribution Platforms   Download Managers   Drawables   Emoji   Emulators   EPUB   Equalizers &   Event Buses   Exception Handling   Face Recognition   Feedback &   File System   File/Directory   Fingerprint   Floating Action   Fonts   Forms   Fragments   FRP   FSM   Functional Programming   Gamepads   Games   Geocaching   Gestures   GIF   Glow Pad   Gradle Plugins   Graphics   Grid Views   Highlighting   HTML   HTTP Mocking   Icons   IDE   IDE Plugins   Image Croppers   Image Loaders   Image Pickers   Image Processing   Image Views   Instrumentation   Intents   Job Schedulers   JSON   Keyboard   Kotlin   Layouts   Library Demos   List View   List Views   Localization   Location   Lock Patterns   Logcat   Logging   Mails   Maps   Markdown   Mathematics   Maven Plugins   MBaaS   Media   Menus   Messaging   MIME   Mobile Web   Native Image   Navigation   NDK   Networking   NFC   NoSQL   Number Pickers   OAuth   Object Mocking   OCR Engines   OpenGL   ORM   Other Pickers   Parallax List   Parcelables   Particle Systems   Password Inputs   PDF   Permissions   Physics Engines   Platforms   Plugin Frameworks   Preferences   Progress Indicators   ProGuard   Properties   Protocol Buffer   Pull To   Purchases   Push/Pull   QR Codes   Quick Return   Radio Buttons   Range Bars   Ratings   Recycler Views   Resources   REST   Ripple Effects   RSS   Screenshots   Scripting   Scroll Views   SDK   Search Inputs   Security   Sensors   Services   Showcase Views   Signatures   Sliding Panels   Snackbars   SOAP   Social Networks   Spannable   Spinners   Splash Screens   SSH   Static Analysis   Status Bars   Styling   SVG   System   Tags   Task Managers   TDD &   Template Engines   Testing   Testing Tools   Text Formatting   Text Views   Text Watchers   Text-to   Toasts   Toolkits For   Tools   Tooltips   Trainings   TV   Twitter   Updaters   USB   User Stories   Utils   Validation   Video   View Adapters   View Pagers   Views   Watch Face   Wearable Data   Wearables   Weather   Web Tools   Web Views   WebRTC   WebSockets   Wheel Widgets   Wi-Fi   Widgets   Windows   Wizards   XML   XMPP   YAML   ZIP Codes