PanelList is a simple library for displaying data. It makes it possible to display massive data on a limited screen, just like what you see in Microsoft Excel.
It could be used to show hotel reservation data (like the demo below), stock data and etc.
If you have any problem using this library, please feel free to contact me via hbdxzyb@hotmail.com.
Don`t forget to star if it helps you. :)
- v1.1 (20170523)— add some APIs
- v1.1.1 (20170723) — add swipe refresh
- v1.1.1.1 (20170812) — add an API to set initial position
- v1.2.0 (20170911) — Big change! Now you can set everything in your activity and call setAdapter() to finish your job. And also some bug fixed.
- v1.2.3(20171112) — Some bug fixed
- v1.3.0(20180416)— simplified normal use, some bug fixed
Something went wrong with jitpack, please download panlelistlibrary and add local dependency, I`m afraid I have to get this fixed later, sorry guys.
Step 1. add this to your project build.gradle
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
Step 2. add this to build.gradle of your module
dependencies {
compile 'com.github.z3896823:PanelList:v1.x.x' //please click the release tag up ahead to fill in the latest version
}
<!--activity view-->
<sysu.zyb.panellistlibrary.PanelListLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/id_pl_root">
<ListView
android:id="@+id/id_lv_content"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fastScrollEnabled="false"
android:overScrollMode="never"/>
</sysu.zyb.panellistlibrary.PanelListLayout>
public class MainActivity extends AppCompatActivity {
private PanelListLayout pl_root;
private ListView lv_content;
private MyPanelListAdapter adapter;
private List<Map<String, String>> contentList = new ArrayList<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
initRowDataList();
initContentDataList();
initItemWidthList();
adapter = new AbstractPanelListAdapter(this,pl_root,lv_content) {
@Override
protected BaseAdapter getContentAdapter() {
return null;
}
};
adapter.setInitPosition(10);
adapter.setSwipeRefreshEnabled(true);
adapter.setRowDataList(rowDataList);
adapter.setTitle("example");
adapter.setOnRefreshListener(new CustomRefreshListener());
adapter.setContentDataList(contentList);
adapter.setItemWidthList(itemWidthList);
adapter.setItemHeight(40);
pl_root.setAdapter(adapter);
// don`t forget to update column manually if you are using a
// custom column data instead of the default 1,2,3...
}
}
public void setTitle(String title);
public void setTitleBackgroundResource(int resourceId);
public void setTitleWidth(int titleWidth) ;
public void setTitleHeight(int titleHeight);
public void setRowDataList(List<String> rowDataList);
public void setColumnDataList(List<String> columnDataList);
public void setRowDivider(Drawable rowDivider) ;
public void setColumnDivider(Drawable columnDivider);
public void setColumnColor(String columnColor);
public void setTitleColor(String titleColor);
public void setRowColor(String rowColor) ;
public void setColumnAdapter(BaseAdapter columnAdapter);
/**
* if you want the 100th data to be your first data on screen, pass 100
*/
public void setInitPosition(int initPosition);
public ListView getContentListView();
public BaseAdapter getContentAdapter();
public ListView getColumnListView();
public BaseAdapter getColumnAdapter();
public LinearLayout getRowLayout();
/**
* default state of swiperefresh is disabled, you can call this method and * pass true to enable it
*/
public void setSwipeRefreshEnabled(boolean bool);
public void setOnRefreshListener(SwipeRefreshLayout.OnRefreshListener listener) ;
public SwipeRefreshLayout getSwipeRefreshLayout();
Copyright 2017 z3896823(hbdxzyb)
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.