AndroidColorPop

Additional

Language
Java
Version
3.0 (Dec 7, 2020)
Created
Feb 27, 2016
Updated
Dec 7, 2020 (Retired)
Owner
Mohsen Fallahi (Mahfa)
Contributor
Mohsen Fallahi (Mahfa)
1
Activity
Badge
Generate
Download
Source code

Advertisement

AndroidColorPop

A library to show a color pop in a new fragment based on position of clicked view.

How to install

Add jitpack in your root build.gradle at the end of repositories:

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

Step 2. Add the dependency

 dependencies {
         implementation 'com.github.Mahfa:AndroidColorPop:3.0'
 }

Usage

Preparing the second fragment to be added in onClick void :

  view.setOnClickListener(new OnClickListener() {

   @Override
   public void onClick(View v) {
    SecondFragment fragment = new SecondFragment();
    // used to inform the second fragment
    FragmentInformer informer = new FragmentInformer(getContext());
    // color of the cricle
    informer.setCircleColor(color);
    // if your views are behind status bar set this to true (Used In API 19+)
    boolean is_views_behind_status_bar = false;
    // the base view that the start point of color pop would be exactly center of that
    // view if mode is set to FragmentInformer.MODE_CENTER
    informer.setBaseView(v, FragmentInformer.MODE_CENTER,
      is_views_behind_status_bar);
    //finally inform the fragment with this call
    informer.informColorPopFragment(fragment);
       //Fragment transaction
    FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();
    transaction.addToBackStack(null);
    transaction.add(android.R.id.content, fragment);
    transaction.commit();
   }
  });

SecondFragment.java :

// note that your class must extend ColorPopFragment or ColorPopPageFragment (which have a different usage)
public class SecondFragmentList extends ColorPopFragment{
    // the base view of fragment
 private View fragment_view;
 
 // this void is called after onCreateView in fragment
 // Note : the visibility of returned view in this method would be set to INVISIBLE
 @Override
 public View onCreateFragmentView(LayoutInflater inflater,
   ViewGroup container, Bundle savedInstanceState) {
  fragment_view = inflater.inflate(R.layout.fragment_second_list,
    container, false);
  return fragment_view;
 }
 // called after the pop animation ends
 @Override
 public void onBackgroundAnimationEnd() {
     // set visibility of fragment_view to VISIBLE
  fragment_view.setVisibility(View.VISIBLE);
 }
}

License

Copyright 2020 Mahdi Fallahi

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.