Java 使用AsyncTask向ExpandableListView填充多个项目
我想用自定义适配器填充ExpandableListView。我在网上发现,我的孩子只有一个(一个文本视图)。在我的例子中,我希望在后台任务之后填充多个子项和数据 请帮我找出我做错了什么,或者我应该做什么,因为我一直在犯错误Java 使用AsyncTask向ExpandableListView填充多个项目,java,android,expandablelistview,Java,Android,Expandablelistview,我想用自定义适配器填充ExpandableListView。我在网上发现,我的孩子只有一个(一个文本视图)。在我的例子中,我希望在后台任务之后填充多个子项和数据 请帮我找出我做错了什么,或者我应该做什么,因为我一直在犯错误 java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Object java.util.HashMap.put(java.lang.Object, java.lang.Objec
java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Object java.util.HashMap.put(java.lang.Object, java.lang.Object)' on a null object reference
at com.infy.texpetrol.Activity.CreditReportActivity$GetData.onPostExecute
信用报告活动
公共类CreditReportActivity扩展了AppCompatActivity{
私有静态最终字符串标记=“CreditBillActivity”;
私有连接类连接类;
私有进程对话;
私人列表cListPetrol、cListDIESEL、cListSPEED、cListOIL;
可扩展列表适配器;
ExpandableListView解释视图;
列表列表数据头;
HashMapListDataChild;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity\u credit\u report);
字符串empCode=getIntent().getStringExtra(“empCode”);
字符串移位=getIntent().getStringExtra(“移位”);
字符串日期=getIntent().getStringExtra(“日期”);
connectionClass=新的connectionClass();
expListView=findViewById(R.id.lvExpandable);
GetData GetData=新建GetData();
执行(empCode);
}
@SuppressLint(“StaticFieldLeak”)
私有类GetData扩展异步任务{
布尔bPetrolRS=false;
布尔bDesiRS=false;
布尔BSPEDS=false;
布尔bOilRS=false;
@凌驾
受保护对象doInBackground(对象[]对象){
字符串empCode=objects[0]。toString();
试一试{
Connection con=connectionClass.CONN();
字符串QueryControl、queryDIESEL、queryOIL、querySPEED;
queryDIESEL=“一些SQL查询”;
queryetrol=“一些SQL查询”;
queryOIL=“一些SQL查询”;
querySPEED=“一些SQL查询”;
如果(con!=null){
语句statement1=con.createStatement();
语句statement2=con.createStatement();
语句statement3=con.createStatement();
语句statement4=con.createStatement();
结果集rsPetrol=statement1.executeQuery(QueryControl);
结果集rsDIESEL=statement2.executeQuery(queryDIESEL);
ResultSet rsOIL=语句3.执行任务(queryOIL);
结果集rsSPEED=statement4.executeQuery(查询速度);
listDataHeader=新的ArrayList();
cListPetrol=newArrayList();
cListDIESEL=newarraylist();
cListSPEED=newarraylist();
cListOIL=newarraylist();
Log.d(标记“doInBackground:rsPetrol”+rsPetrol.next());
if(rsPetrol.next()){
while(rsPetrol.next()){
bPetrolRS=true;
cListPetrol.add(rsPetrol.getString(“PartyName”)
+“#.#”+rsPetrol.getString(“数量”)
+“#.#”+rsPetrol.getString(“金额”);
}
}否则{
bPetrolRS=false;
cListPetrol.添加(“无”);
}
Log.d(标记“doInBackground:rsDIESEL”+rsDIESEL.next());
if(rsDIESEL.next()){
while(rsDIESEL.next()){
bDesiRS=true;
cListDIESEL.add(rsDIESEL.getString(“PartyName”)
+“#.#”+rsDIESEL.getString(“数量”)
+“#.#”+rsDIESEL.getString(“金额”);
}
}否则{
bDesiRS=假;
cListDIESEL.添加(“无”);
}
Log.d(标记“doInBackground:rsSPEED”+rsSPEED.next());
if(rsSPEED.next()){
while(rsSPEED.next()){
bspedss=真;
cListSPEED.add(rsSPEED.getString(“PartyName”)
+“#.#”+rsSPEED.getString(“数量”)
+“#.#”+rsSPEED.getString(“金额”);
}
}否则{
bspedss=假;
cListSPEED.add(“无”);
}
Log.d(标记“doInBackground:rsOIL”+rsOIL.next());
if(rsOIL.next()){
while(rsOIL.next()){
bOilRS=true;
cListOIL.add(rsOIL.getString(“PartyName”)
+“#.#”+rsOIL.getString(“数量”)
+“#.#”+rsOIL.getString(“金额”);
}
}否则{
bspedss=假;
cListOIL.添加(“无”);
}
}否则{
Log.d(标记“doInBackground:连接错误”);
}
}捕获(例外e){
bPetrolRS=false;
Log.d(标记“doInBackground:CATCH”+e.getMessage());
}
返回EMP码;
}
@凌驾
受保护的void onPostExecute(对象o){
progressDialog.hide();
如果(!o.toString().isEmpty()){
添加(“柴油机”);
listDataHeader.添加(“汽油”);
添加(“速度”);
listDataHeader.添加(“油”);
如果(bDesiRS){
Log.d(标记“onPostExecute:cListDIESEL”+cListDIESEL.size()+“listDataHeader.get(0)”+listDataHeader.get(0));
listDataChild.put(listDataHeader.get(0),cListDIESEL);
}否则{
Toast.makeText(CreditReportActivity.this,“柴油机中无数据”,Toast.LENGTH_SHORT.show();
}
if(bPetrolRS){
Log.d(标记“onPostExecute:cListPetrol”+cListPetrol.size()+“listDataHeader.get(1)”+listDataHe
public class CreditReportActivity extends AppCompatActivity {
private static final String TAG = "CreditBillActivity";
private ConnectionClass connectionClass;
private ProgressDialog progressDialog;
private List<String> cListPetrol, cListDIESEL, cListSPEED, cListOIL;
ExpandableListAdapter listAdapter;
ExpandableListView expListView;
List<String> listDataHeader;
HashMap<String, List<String>> listDataChild;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_credit_report);
String empCode = getIntent().getStringExtra("empCode");
String shift = getIntent().getStringExtra("shift");
String date = getIntent().getStringExtra("date");
connectionClass = new ConnectionClass();
expListView = findViewById(R.id.lvExpandable);
GetData getData = new GetData();
getData.execute(empCode);
}
@SuppressLint("StaticFieldLeak")
private class GetData extends AsyncTask {
boolean bPetrolRS = false;
boolean bDesiRS = false;
boolean bSpedRS = false;
boolean bOilRS = false;
@Override
protected Object doInBackground(Object[] objects) {
String empCode = objects[0].toString();
try {
Connection con = connectionClass.CONN();
String queryPetrol, queryDIESEL, queryOIL, querySPEED;
queryDIESEL = "Some SQL QUERY";
queryPetrol = "Some SQL QUERY";
queryOIL = "Some SQL QUERY";
querySPEED = "Some SQL QUERY";
if (con != null) {
Statement statement1 = con.createStatement();
Statement statement2 = con.createStatement();
Statement statement3 = con.createStatement();
Statement statement4 = con.createStatement();
ResultSet rsPetrol = statement1.executeQuery(queryPetrol);
ResultSet rsDIESEL = statement2.executeQuery(queryDIESEL);
ResultSet rsOIL = statement3.executeQuery(queryOIL);
ResultSet rsSPEED = statement4.executeQuery(querySPEED);
listDataHeader = new ArrayList<>();
cListPetrol = new ArrayList<>();
cListDIESEL = new ArrayList<>();
cListSPEED = new ArrayList<>();
cListOIL = new ArrayList<>();
Log.d(TAG, "doInBackground: rsPetrol " + rsPetrol.next());
if (rsPetrol.next()) {
while (rsPetrol.next()) {
bPetrolRS = true;
cListPetrol.add(rsPetrol.getString("PartyName")
+ "#.#" + rsPetrol.getString("QTY")
+ "#.#" + rsPetrol.getString("Amount"));
}
} else {
bPetrolRS = false;
cListPetrol.add("NONE");
}
Log.d(TAG, "doInBackground: rsDIESEL " + rsDIESEL.next());
if (rsDIESEL.next()) {
while (rsDIESEL.next()) {
bDesiRS = true;
cListDIESEL.add(rsDIESEL.getString("PartyName")
+ "#.#" + rsDIESEL.getString("QTY")
+ "#.#" + rsDIESEL.getString("Amount"));
}
} else {
bDesiRS = false;
cListDIESEL.add("NONE");
}
Log.d(TAG, "doInBackground: rsSPEED " + rsSPEED.next());
if (rsSPEED.next()) {
while (rsSPEED.next()) {
bSpedRS = true;
cListSPEED.add(rsSPEED.getString("PartyName")
+ "#.#" + rsSPEED.getString("QTY")
+ "#.#" + rsSPEED.getString("Amount"));
}
} else {
bSpedRS = false;
cListSPEED.add("NONE");
}
Log.d(TAG, "doInBackground: rsOIL " + rsOIL.next());
if (rsOIL.next()) {
while (rsOIL.next()) {
bOilRS = true;
cListOIL.add(rsOIL.getString("PartyName")
+ "#.#" + rsOIL.getString("QTY")
+ "#.#" + rsOIL.getString("Amount"));
}
} else {
bSpedRS = false;
cListOIL.add("NONE");
}
} else {
Log.d(TAG, "doInBackground: Error in Connection");
}
} catch (Exception e) {
bPetrolRS = false;
Log.d(TAG, "doInBackground: CATCH " + e.getMessage());
}
return empCode;
}
@Override
protected void onPostExecute(Object o) {
progressDialog.hide();
if (!o.toString().isEmpty()) {
listDataHeader.add("DIESEL");
listDataHeader.add("PETROL");
listDataHeader.add("SPEED");
listDataHeader.add("OIL");
if (bDesiRS) {
Log.d(TAG, "onPostExecute: cListDIESEL " + cListDIESEL.size() + " listDataHeader.get(0) " + listDataHeader.get(0));
listDataChild.put(listDataHeader.get(0), cListDIESEL);
} else {
Toast.makeText(CreditReportActivity.this, "NO DATA IN DIESEL", Toast.LENGTH_SHORT).show();
}
if (bPetrolRS) {
Log.d(TAG, "onPostExecute: cListPetrol " + cListPetrol.size() + " listDataHeader.get(1) " + listDataHeader.get(1));
listDataChild.put(listDataHeader.get(1), cListPetrol); //error gets me here
} else {
Toast.makeText(CreditReportActivity.this, "NO DATA IN PETROL", Toast.LENGTH_SHORT).show();
}
if (bOilRS) {
listDataChild.put(listDataHeader.get(2), cListSPEED);
Log.d(TAG, "onPostExecute: cListSPEED " + cListSPEED.size());
} else {
Toast.makeText(CreditReportActivity.this, "NO DATA IN SPEED", Toast.LENGTH_SHORT).show();
}
if (bSpedRS) {
listDataChild.put(listDataHeader.get(3), cListOIL);
Log.d(TAG, "onPostExecute: cListOIL " + cListOIL.size());
} else {
Toast.makeText(CreditReportActivity.this, "NO DATA IN OIL", Toast.LENGTH_SHORT).show();
}
listAdapter = new ExpandableListAdapter(CreditReportActivity.this, listDataHeader, listDataChild);
expListView.setAdapter(listAdapter);
} else {
Toast.makeText(CreditReportActivity.this, "No Data", Toast.LENGTH_SHORT).show();
}
}
@Override
protected void onPreExecute() {
progressDialog = new ProgressDialog(CreditReportActivity.this);
progressDialog.setMessage("Getting your Report");
progressDialog.show();
}
}
}
public class ExpandableListAdapter extends BaseExpandableListAdapter {
private Context _context;
private List<String> _listDataHeader; // header titles
// child data in format of header title, child title
private HashMap<String, List<String>> _listDataChild;
private String[] split;
public ExpandableListAdapter(Context _context, List<String> _listDataHeader, HashMap<String, List<String>> _listDataChild) {
this._context = _context;
this._listDataHeader = _listDataHeader;
this._listDataChild = _listDataChild;
}
@Override
public Object getChild(int groupPosition, int childPosition) {
return Objects.requireNonNull(this._listDataChild.get(this._listDataHeader.get(groupPosition))).get(childPosition);
}
@Override
public long getChildId(int groupPosition, int childPosition) {
return childPosition;
}
@SuppressLint("InflateParams")
@Override
public View getChildView(int groupPosition, final int childPosition, boolean isLastChild, View convertView, ViewGroup parent) {
final String childText = (String) getChild(groupPosition, childPosition);
stringSplit(childText);
if (convertView == null) {
LayoutInflater Inflater = (LayoutInflater) this._context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
convertView = Inflater.inflate(R.layout.child, null);
}
TextView txtPartyName = convertView.findViewById(R.id.txt_C_partyName);
txtPartyName.setText(split[0]);
TextView product = convertView.findViewById(R.id.txt_C_COUNT);
product.setText(String.valueOf(childPosition));
TextView qty = convertView.findViewById(R.id.txt_C_qty);
qty.setText(split[1]);
TextView amt = convertView.findViewById(R.id.txt_C_amt);
amt.setText(split[2]);
return convertView;
}
private void stringSplit(String childText) {
split = childText.split("#.#");
}
@Override
public int getChildrenCount(int groupPosition) {
return Objects.requireNonNull(this._listDataChild.get(this._listDataHeader.get(groupPosition)))
.size();
}
@Override
public Object getGroup(int groupPosition) {
return this._listDataHeader.get(groupPosition);
}
@Override
public int getGroupCount() {
return this._listDataHeader.size();
}
@Override
public long getGroupId(int groupPosition) {
return groupPosition;
}
@SuppressLint("InflateParams")
@Override
public View getGroupView(int groupPosition, boolean isExpanded,
View convertView, ViewGroup parent) {
String headerTitle = (String) getGroup(groupPosition);
if (convertView == null) {
LayoutInflater infalInflater = (LayoutInflater) this._context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
convertView = infalInflater.inflate(R.layout.header, null);
}
TextView lblListHeader = convertView.findViewById(R.id.lblListHeader);
lblListHeader.setTypeface(null, Typeface.BOLD);
lblListHeader.setText(headerTitle);
return convertView;
}
@Override
public boolean hasStableIds() {
return false;
}
@Override
public boolean isChildSelectable(int groupPosition, int childPosition) {
return false;
}
HashMap<String, List<String>> listDataChild = new HashMap<>();