android listview 删除之后怎么刷新 listview

这个是TitleAdapter

package com.example.ming.myapplication;

import android.content.Context;
import android.content.Intent;
import android.os.AsyncTask;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;

import java.net.MalformedURLException;
import java.net.URL;
import java.util.List;

public class TitleAdapter extends BaseAdapter {
Context context;
List postlist2;
String id2;
String id="";
int ii=0;

public TitleAdapter(Context context, List<Article> postlist) {

    this.context = context;
    this.postlist2 = postlist;

}

@Override
public int getCount() {
    return postlist2.size();
}

@Override
public Object getItem(int position) {
    return null;
}

@Override
public long getItemId(int position) {
    return 0;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    convertView = LayoutInflater.from(context).inflate(R.layout.activity_article, null);
    Object obj = convertView.getTag();

    ii=position;

    ViewHolder holder;//实现缓存 高效加载数据
    //如果为空
    if (obj == null) {
        holder = new ViewHolder(convertView);
        convertView.setTag(holder);
    } else {
        //緩存 通過viewholder存儲
        holder = (ViewHolder) obj;
    }
    Article posit = postlist2.get(position);
    holder.tv_tltleid.setText(posit.getWid() + "");
    holder.tv_tltlecontent.setText(posit.getTitle() + "");

    return convertView;
}

public class ViewHolder  {
    public View lv_title;
    public TextView tv_tltleid;
    public TextView tv_tltlecontent;
    public Button btn_neirong;
    public Button btn_delete;
    public ViewHolder(View rootView) {
        this.lv_title = rootView;
        this.tv_tltleid = (TextView) rootView.findViewById(R.id.tv_tltleid);
        this.tv_tltlecontent = (TextView) rootView.findViewById(R.id.tv_tltlecontent);

        this.btn_neirong=(Button)rootView.findViewById(R.id.btn_neirong);
        btn_neirong.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {


                Intent intent2 = new Intent(context, ContentActivity.class);
                String id2=tv_tltleid.getText().toString();
                Log.i("aaa",id2);
                intent2.putExtra("wid",id2);
                context.startActivity(intent2);
            }
        });


        this.btn_delete = (Button) rootView.findViewById(R.id.btn_delete);
        btn_delete.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {


                String id = tv_tltleid.getText().toString();
                Log.i("1111", id);
                Log.i("11112", id);
                String url = "http://192.168.43.124:8080/test1/LoginServlet?jsp=delete&wid=" + id;
                new LoginTask().execute(url);
            }
        });

    }

    class LoginTask extends AsyncTask<String, Integer, String> {
        @Override
        protected String doInBackground(String... params) {
            String par = params[0];
            URL url = null;
            try {
                url = new URL(par);
            } catch (MalformedURLException e) {
                e.printStackTrace();
            }
            String result = HttpUtil.doPost(url);
            return result;
        }

        //第四步
        @Override
        protected void onPostExecute(String result) {
            super.onPostExecute(result);
            //保存数据

            if (result.equals("1")) {

                Toast.makeText(context, "删除成功", Toast.LENGTH_SHORT).show();

                return;
            } else {
                if (result.equals("-1")) {
                    Toast.makeText(context, "删除失败", Toast.LENGTH_SHORT).show();
                    return;
                }
            }
        }
    }



}

}

这个是TitleActivity

package com.example.ming.myapplication;

import android.content.Context;
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.widget.Button;
import android.widget.ListView;

import com.google.gson.Gson;
import com.google.gson.reflect.TypeToken;

import org.json.JSONArray;

import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

/**

  • Created by Ming on 2019/6/16. */

public class TitleActivity extends AppCompatActivity {

private ListView listView;

Article article;
JSONArray jsonArray;
ListView lv_title;
Context context;
Button button;
String id2="used";

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_title);

    Intent intent=getIntent();

    id2=intent.getStringExtra("id2");
    context = this;
    String url = "http://192.168.43.124:8080/test1/LoginServlet?jsp=titleck&id2="+id2;
    new LoginTask().execute(url);

}



class LoginTask extends AsyncTask<String, Integer, String> {
    @Override
    protected String doInBackground(String... params) {
        String par = params[0];
        URL url = null;
        try {
            url = new URL(par);
        } catch (MalformedURLException e) {
            e.printStackTrace();
        }
        String result = HttpUtil.doPost(url);

        return result;
    }

    //第四步
    @Override
    protected void onPostExecute(String result) {
        super.onPostExecute(result);


        final List<Article> list = new ArrayList<Article>();

        Gson gson1 = new Gson();
        final List<Article> list2 = gson1.fromJson(result, new TypeToken<List<Article>>() {
        }.getType());
        for (Article person1 : list) {
            System.out.println(person1.toString());
        }


        lv_title=(ListView)findViewById(R.id.lv_title);

        lv_title.setAdapter(new TitleAdapter(context,list2));


    }

}

}
1.

3个回答

notifyDataSetChanged();

as_csdn
取个什么名字好。 回复weixin_45274972: 参考这篇文章吧:https://www.jianshu.com/p/50515c3160d3
12 个月之前 回复
as_csdn
取个什么名字好。 回复weixin_45274972: 一般来说,通常的做法是在对应的adapter中写一个删除方法,类似这样的:public void deletItem(int pos) { DebugLog.e(pos + "删除的position"); mData.remove(pos); this.notifyDataSetChanged(); },执行删除操作时调用,其中的mData就是数据列表,参数是要删除的数据的position
12 个月之前 回复
weixin_45274972
weixin_45274972 this.btn_delete = (Button) rootView.findViewById(R.id.btn_delete); btn_delete.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String id = tv_tltleid.getText().toString(); Log.i("1111", id); //192.168.43.124 String url = "http://220.202.158.368080/test1/LoginServlet?jsp=delete&wid=" + id; new LoginTask().execute(url); notifyDataSetChanged(); } }); 是这样写吗?但是他还是没有刷新数据
12 个月之前 回复
weixin_45274972
weixin_45274972 回复流浪_过客: this.btn_delete = (Button) rootView.findViewById(R.id.btn_delete); btn_delete.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String id = tv_tltleid.getText().toString(); Log.i("1111", id); Log.i("11112", id); String url = "http://192.168.43.1248080/test1/LoginServlet?jsp=delete&wid=" + id; new LoginTask().execute(url); } });
12 个月之前 回复
as_csdn
取个什么名字好。 回复weixin_45274972: 在你执行完删除操作后,调用这个方法就行了,这是adapter自带的
12 个月之前 回复
weixin_45274972
weixin_45274972 请问是怎么写呢?能详细一点吗?我不太懂安卓不好意思。
12 个月之前 回复

建议使用recyclerview. listview也可以实现删除. 但是不太好用.

qq_32508519
Jimmy_buer 回复weixin_45274972: 当然可以. listview完全支持删除刷新.只是早都不用这个了.
12 个月之前 回复
fjd19921225
彩虹直至黑白iii丶 建议使用recyclerview. listview也可以实现删除. 但是不太好用.
12 个月之前 回复
weixin_45274972
weixin_45274972 那我这个删除就不能刷新了吗?
12 个月之前 回复

先用postlist2 .remove(position) 在调用notifyDataSetChanged();

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
android ListView长按删除之后,调用notifyDataSetChanged

ListView 长按删除之后,调用notifyDataSetChanged但是界面上仍然显示此条数据,怎么回事啊 ![图片说明](https://img-ask.csdn.net/upload/201508/17/1439810797_65701.png)

删除后android刷新Listview

在我的item删除后我想要刷新我的listview。但是好像不起作用,我是少了什么东西了么?我用了`listAdapter.notifyDataSetChanged();`也不起作用。有没有人能帮帮我?谢谢。 @Override public void onActivityCreated(Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); getActivity().setContentView(R.layout.dl_listview); View empty = getActivity().findViewById(R.id.empty); DLListView = (ListView) getActivity().findViewById(R.id.DLListView); DLListView.setEmptyView(empty); if (!Environment.getExternalStorageState().equals( Environment.MEDIA_MOUNTED)) { Toast.makeText(getActivity(), "Error! No SDCARD Found!", Toast.LENGTH_LONG).show(); } else { File directory = new File(Environment.getExternalStorageDirectory() + File.separator + "St"); directory.mkdirs(); } DLListView = (ListView) getActivity().findViewById(R.id.DLListView); myList = new ArrayList<String>(); File sdCard = Environment.getExternalStorageDirectory(); file = new File(sdCard.getAbsolutePath() + "/St/"); File list[] = file.listFiles(); for (int i = 0; i < list.length; i++) { String fileName = list[i].getName(); fileName = fileName.replace(".txt", ""); myList.add(fileName); } listAdapter = new ArrayAdapter<String>(getActivity(), R.layout.simplerow, myList); DLListView.setAdapter(listAdapter); DLListView.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { // TODO Auto-generated method stub String textToPass = myList.get(position); Intent i = new Intent(getActivity(), ViewActivity.class); textToPass = textToPass.replace(textToPass + "", textToPass + ".txt"); i.putExtra("textToPass", textToPass); startActivity(i); } }); DLListView.setOnItemLongClickListener(new OnItemLongClickListener() { @Override public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) { // TODO Auto-generated method stub registerForContextMenu(DLListView); return false; } }); } public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) { super.onCreateContextMenu(menu, v, menuInfo); AdapterContextMenuInfo info = (AdapterContextMenuInfo) menuInfo; String name = ((TextView) info.targetView).getText().toString(); menu.setHeaderTitle(name); menu.add(0, v.getId(), 0, "Delete"); } @Override public boolean onContextItemSelected(MenuItem item) { deletefunc(item.getItemId()); return true; } public void deletefunc(int id) { String filenamec = fileName1; filenamec = filenamec.replace(filenamec + "", filenamec + ".txt"); File folder = Environment.getExternalStorageDirectory(); String fileName = folder.getPath() + "/St/" + filenamec; File myFile = new File(fileName); if (myFile.exists()) myFile.delete(); Toast.makeText(getActivity(), fileName1+" Deleted", Toast.LENGTH_SHORT) .show(); listAdapter.remove(listAdapter.getItem(id)); } LogCat : 12-26 11:57:27.334: E/AndroidRuntime(5576): FATAL EXCEPTION: main 12-26 11:57:27.334: E/AndroidRuntime(5576): java.lang.IndexOutOfBoundsException: Invalid index 2131034154, size is 1 12-26 11:57:27.334: E/AndroidRuntime(5576): at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:251) 12-26 11:57:27.334: E/AndroidRuntime(5576): at java.util.ArrayList.get(ArrayList.java:304) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.widget.ArrayAdapter.getItem(ArrayAdapter.java:337) 12-26 11:57:27.334: E/AndroidRuntime(5576): at free.st.app.MyDownloads.deletefunc(MyDownloads.java:137) 12-26 11:57:27.334: E/AndroidRuntime(5576): at free.st.app.MyDownloads.onContextItemSelected(MyDownloads.java:118) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.support.v4.app.FragmentManagerImpl.dispatchContextItemSelected(FragmentManager.java:1933) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.support.v4.app.FragmentActivity.onMenuItemSelected(FragmentActivity.java:360) 12-26 11:57:27.334: E/AndroidRuntime(5576): at com.actionbarsherlock.app.SherlockFragmentActivity.onMenuItemSelected(SherlockFragmentActivity.java:200) 12-26 11:57:27.334: E/AndroidRuntime(5576): at com.android.internal.policy.impl.PhoneWindow$DialogMenuCallback.onMenuItemSelected(PhoneWindow.java:3691) 12-26 11:57:27.334: E/AndroidRuntime(5576): at com.android.internal.view.menu.MenuBuilder.dispatchMenuItemSelected(MenuBuilder.java:735) 12-26 11:57:27.334: E/AndroidRuntime(5576): at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:149) 12-26 11:57:27.334: E/AndroidRuntime(5576): at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:874) 12-26 11:57:27.334: E/AndroidRuntime(5576): at com.android.internal.view.menu.MenuDialogHelper.onClick(MenuDialogHelper.java:167) 12-26 11:57:27.334: E/AndroidRuntime(5576): at com.android.internal.app.AlertController$AlertParams$3.onItemClick(AlertController.java:929) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.widget.AdapterView.performItemClick(AdapterView.java:292) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.widget.AbsListView.performItemClick(AbsListView.java:1185) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.widget.AbsListView$PerformClick.run(AbsListView.java:2713) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.widget.AbsListView$1.run(AbsListView.java:3468) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.os.Handler.handleCallback(Handler.java:605) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.os.Handler.dispatchMessage(Handler.java:92) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.os.Looper.loop(Looper.java:137) 12-26 11:57:27.334: E/AndroidRuntime(5576): at android.app.ActivityThread.main(ActivityThread.java:4512) 12-26 11:57:27.334: E/AndroidRuntime(5576): at java.lang.reflect.Method.invokeNative(Native Method) 12-26 11:57:27.334: E/AndroidRuntime(5576): at java.lang.reflect.Method.invoke(Method.java:511) 12-26 11:57:27.334: E/AndroidRuntime(5576): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:982) 12-26 11:57:27.334: E/AndroidRuntime(5576): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749) 12-26 11:57:27.334: E/AndroidRuntime(5576): at dalvik.system.NativeStart.main(Native Method)

Android ListView点击之后传递数据到Webview并显示

在ListView中点击一条,拿到对应条数据之后该怎么将数据传到一个WebView中显示,Android端如何传递,WebView该如何接收(WebView用JQM实现)

android listview 删除item同时删除对应行数的数据库内容

``` listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?>parent,View view,int position,long id) { Map<String, Object> positioncurrent = list.get(position); comment.setId(Integer.parseInt(String.valueOf(positioncurrent))); int _id = comment.getId(); SQLiteDatabase db = databaseHelper.getWritableDatabase(); db.delete("comment",Comment.Commentinter.EVENT_ID + getString(R.string.dlx_wenhao),new String[]{String.valueOf(id)}); db.close(); list.remove(positioncurrent); adapter.notifyDataSetChanged(); listView.setAdapter(adapter); } }); } ``` 我完全新手,这是我写的监听事件,Comment类里是我数据库表属性的setget方法,逻辑上不知道对不对,只是现在它报错, java.lang.ClassCastException: java.util.HashMap cannot be cast to com.example.dengfugui.myapplication.Comment,不让我把positioncurrent进行类型转换,我应该怎么修改?或者基于我的 Map<String, Object>和Comment有没有啥更好的方法?求大神指点!!!!谢谢了!!!

android listView 删除动画 当前Item 删了,但是动画总是从最后一行执行

点击ListView 的item中的控件,删除当前item时,想让它一动画的方式 消失,但是,点击删除时,item可以删除掉,但是动画总是执行的最后一行 求解、?? 这是主要代码 @Override public View getView(final int position, View convertView, ViewGroup parent) { if (convertView == null) { convertView = LayoutInflater.from(mActivity).inflate(R.layout.layout_dialog_item_detial, null); holder = new ViewHolder(); holder.tv_time = (TextView) convertView.findViewById(R.id.tv_time); holder.tv_score = (TextView) convertView.findViewById(R.id.tv_score); holder.iv_delete = (ImageView) convertView.findViewById(R.id.iv_delete); convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } DiagHistory dh = historyLists.get(position); holder.tv_time.setText(dh.getScanTime()); holder.tv_score.setText(dh.getDiaScore()); holder.iv_delete.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { View itemView = (View) holder.iv_delete.getParent(); removeListItem(itemView, position); SQLLiteService.getInstance(mActivity).deleteDialogHistory(holder.tv_time.getText().toString().trim()); } }); return convertView; } class ViewHolder { TextView tv_time, tv_score; ImageView iv_delete; } private void removeListItem(View rowView, final int positon) { final Animation animation = (Animation) AnimationUtils.loadAnimation(rowView.getContext(), R.anim.remove_dialog_list_item); animation.setAnimationListener(new AnimationListener() { public void onAnimationStart(Animation animation) { } public void onAnimationRepeat(Animation animation) { } public void onAnimationEnd(Animation animation) { historyLists.remove(positon); DialogItemDetailAdapter.this.notifyDataSetChanged(); animation.cancel(); } }); rowView.startAnimation(animation); }

Android中,刷新ListView中的item导致ListView闪烁的解决方法

如题,因为下载列表使用ListView实现的,所以必须实时更新ListView中的数据。 我采用的是Service+BroadcastReceiver的搭配。更新数据 在Activity里面再用notifySetDataChange()的方法对ListView进行动态刷新 但是发现一个很严重的问题。刷新的时候ListView有明显的闪烁。 求解决方法

android listview闪退问题

listview有时候会闪退,有时候不会,而且滚动刷新数据的时候有时候会闪退有时候不会,adapter.notifyDataSetChanged()有加.

listView的局部刷新丶单条数据刷新

![图片说明](https://img-ask.csdn.net/upload/201701/19/1484790285_764769.jpg) 如图所示,我扫描一个单号并进行操作,实现卸货,如果总数量和卸货数量相等则移除给条数据,否则就将卸货数量加一?这要怎么实现卸货数量加一呢?

listview删除item后Fragment刷新问题

android开发 我的Fragment中有一个listview,设置了长按删除item的功能,现在的问题是,我adapter.notifyDataSetChanged();是会重新加载listview,但是我的listview下面有一个imageview,就会出现删除的那个item空白,而imageview不会占据那个删除的item的位置,比如说,我123+,删除3,就会出现12 +,我不会删除那个空白,我就想能不能重新加载这个Fragment,网上的都看不懂,求大神指导一下~

Android listview与数据库同步问题

根据所选listview列表项的下标 , 对应数据库中设置的id进行删除列表项,假如一共有五个项,当我删除第五个项时,界面里还剩四个项,再当我添加一个项时,数据库里ID为6了,但界面里还是第五项,所以当我获取该项下标时为5,但数据库里的id却为6了!所以导致不能删掉,id和listview下标不同步,求解,谢谢

点击按钮从 ListView中 删除一行

程序中的 ListView 的行包含一些 textviews 和一个按钮。当用户点击按钮时,我想删除父类 并把按钮从 ListView中 删除。如何在一个嵌套的方法(onClickListener)中访问自定义的 ArrayAdapter 的字段?我使用的是 View v。我是否要多次调用 v.getParent(),或者还有什么更好的方法? @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder = null; Action item = this.getItem(position); if (convertView == null) { convertView = inflater.inflate(R.layout.action_holder_layout, parent, false); holder = new ViewHolder(); holder.title = (TextView) convertView .findViewById(R.id.action_holder_title); holder.finishBtn = (Button) convertView .findViewById(R.id.finish_action_button); convertView.setTag(holder); } else holder = (ViewHolder) convertView.getTag(); holder.title.setText(item.getActionName()); holder.finishBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { //REMOVE THE ACTION FROM THE ADAPTER'S ARRAYLIST } }); return convertView; } static class ViewHolder { private TextView title; private Button finishBtn; }

android ListView一直添加数据导致OOM怎么办?

给listView设置了下拉刷新,但是发现如果我一直刷新,一直添加数据的话,内存使用会越来越大,最后导致OOM?怎么解决啊?

android ListView 怎么通过键盘的del键 删除listView的选中项

为了适应有键盘的手机,添加了del键 直接删除 通过手机上下键选中的项目 我是这样做的 setChoiceMode(ListView.CHOICE_MODE_SINGLE) public boolean onKeyUp(int keyCode, KeyEvent event) { Log.i(TAG, "keyCode:"+keyCode); if(keyCode==KeyEvent.KEYCODE_DEL) { Log.i(TAG, "del"); if(myListView != null) { myListView.getCheckedItemPosition(); Log.i(TAG, ""+myListView.getItemsCanFocus()+myListView.getCheckedItemPosition()); int selectId=myListView.getCheckedItemPosition(); Log.i(TAG, "selectId:"+ selectId); if(selectId !=-1) { // TODO Auto-generated method stub showDeleteAlertDialog(showList.get(selectId));//删除的方法 } } } else if(keyCode==KeyEvent.KEYCODE_BACK) { onBackPressed(); } return super.onKeyDown(keyCode, event); } 可是这样一直获取不到焦点 和选择的项目 我该怎么做??怎么获取通过手机上下键选中的listView的项目??

AndroidSQLite数据库删除数据后ListView的更新

一款记账的软件,我的数据存储在SQLite中,当我长按item时,弹出对话框并确定删除该item,但是数据库中的删掉了,activity中的listView中该item还在,依理来说是因为我的adapter适配器加载的还是内存中的数据,但是小白还是没有想到好的解决办法,我试了使用广播,但是出现整个页面的item都被删了(数据库的其他还在)。其他的各种办法也都试了还是不行,无奈求助各位看到帖子的大神。讲解的好,我绝对给高分。先谢过各位了。 ![图片说明](https://img-ask.csdn.net/upload/201703/22/1490187215_17835.png) 适配器代码在此: ``` public class CostListAdapter extends BaseAdapter { private List<CostBean> mList; private Context mContext; private LayoutInflater mInflater; public CostListAdapter(Context context, final List<CostBean> list){ mContext = context; mList = list; mInflater = LayoutInflater.from(context); IntentFilter intentFilter = new IntentFilter(); intentFilter.addAction("com.zsf.accountbook.MY_BROADCAST"); context.registerReceiver(new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { mList.clear(); mList = list; notifyDataSetChanged(); } },intentFilter); } @Override public int getCount() { return mList.size(); } @Override public Object getItem(int position) { return mList.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder = null; if (convertView == null){ holder = new ViewHolder(); convertView = mInflater.inflate(R.layout.list_item,null); holder.mTvCostCategory = (TextView) convertView.findViewById(R.id.tv_category); holder.mTvCostDate = (TextView) convertView.findViewById(R.id.tv_date); holder.mTvCostMoney = (TextView) convertView.findViewById(R.id.tv_money); convertView.setTag(holder); }else { holder = (ViewHolder) convertView.getTag(); } CostBean costBean = mList.get(position);// holder.mTvCostCategory.setText(costBean.costCategory); holder.mTvCostDate.setText(costBean.costDate); holder.mTvCostMoney.setText(costBean.costMoney); return convertView; } private static class ViewHolder{ public TextView mTvCostCategory; public TextView mTvCostDate; public TextView mTvCostMoney; } } ``` ![图片说明](https://img-ask.csdn.net/upload/201703/22/1490187234_665074.png) ![图片说明](https://img-ask.csdn.net/upload/201703/22/1490187852_566687.gif) 漏掉了数据库部分的代码: ![图片说明](https://img-ask.csdn.net/upload/201703/22/1490188335_213349.png)

listview 如何删除sdcard卡文件并刷新界面?红色部分

package com.genny; import java.io.File; import android.app.Activity; import android.app.AlertDialog; import android.content.ContentResolver; import android.content.DialogInterface; import android.content.Intent; import android.content.IntentFilter; import android.database.Cursor; import android.graphics.Color; import android.net.Uri; import android.os.Bundle; import android.os.Environment; import android.provider.MediaStore; import android.view.ContextMenu; import android.view.Gravity; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.ContextMenu.ContextMenuInfo; import android.view.ViewGroup.LayoutParams; import android.widget.AdapterView; import android.widget.CursorAdapter; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.RelativeLayout; import android.widget.SimpleAdapter; import android.widget.SimpleCursorAdapter; import android.widget.TextView; import android.widget.Toast; import android.widget.AdapterView.*; public class MusicListActivity extends Activity{ private ListView listview; private Cursor c = null; private File file = null; private CursorAdapter adapter; private ScanSdReceiver scanSdReceiver = null; private String[] _title = null; private String[] _name = null; private String[] _size; private String[] _path = null; private String[] _singer = null; private String[] _album = null; private int[] _time; private int index; //menu菜单 private static final int ITEM1 = Menu.FIRST; private static final int ITEM2 = Menu.FIRST + 1; private static final int ITEM3 = Menu.FIRST + 2; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.musiclist); listview = (ListView)findViewById(android.R.id.list); c = this.getContentResolver() .query(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, new String[]{MediaStore.Audio.Media.TITLE,//歌曲名0 MediaStore.Audio.Media.DURATION,//时长1 MediaStore.Audio.Media.ARTIST,//歌手2 MediaStore.Audio.Media._ID,//ID3 MediaStore.Audio.Media.DISPLAY_NAME,//文件名4 MediaStore.Audio.Media.ALBUM,//专辑5 MediaStore.Audio.Media.SIZE,//大小6 MediaStore.Audio.Media.DATA},//路径7 null, null, null); /* if (c==null || c.getCount()==0){ builder = new AlertDialog.Builder(this); builder.setMessage("存储列表为空...").setPositiveButton("确定", null); ad = builder.create(); ad.show(); }*/ c.moveToFirst(); _title = new String[c.getCount()]; _name = new String[c.getCount()]; _path = new String[c.getCount()]; _singer = new String[c.getCount()]; _album = new String[c.getCount()]; _size = new String[c.getCount()]; _time = new int[c.getCount()]; for(int i=0;i<c.getCount();i++){ _title[i] = c.getString(0); _name[i] = c.getString(4); _path[i] = c.getString(7); _singer[i] = c.getString(2); _album[i] = c.getString(5); _size[i] = c.getString(6); _time[i] = c.getInt(1); c.moveToNext(); } adapter = new SimpleCursorAdapter(this, R.layout.listitem, c, new String[]{MediaStore.Audio.AudioColumns.TITLE, MediaStore.Audio.AudioColumns.ARTIST}, new int[]{R.id.music, R.id.songer}); listview.setAdapter(adapter); listview.setOnItemClickListener(new ListItemClickListener()); registerForContextMenu(listview); } class ListItemClickListener implements OnItemClickListener{ @Override public void onItemClick(AdapterView<?> arg0, View view, int position, long id) { // TODO Auto-generated method stub Intent i = new Intent(MusicPlayerService.MUSIC_CONTROL); i.putExtra("cmd", MusicPlayerService.CMD_JUMP); i.putExtra("pos", position); sendBroadcast(i); finish(); } } @Override public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) { // TODO Auto-generated method stub index = ((AdapterContextMenuInfo)menuInfo).position;//获取menu点击项的position menu.setHeaderIcon(R.drawable.header_icon); menu.setHeaderTitle(_title[index]); menu.add(0,ITEM1,0,"播放"); menu.add(0,ITEM2,0,"删除"); menu.add(0,ITEM3,0,"详细"); super.onCreateContextMenu(menu, v, menuInfo); } public boolean onContextItemSelected(MenuItem item){ switch(item.getItemId()){ case ITEM1: Intent i = new Intent(MusicPlayerService.MUSIC_CONTROL); i.putExtra("cmd", MusicPlayerService.CMD_JUMP); i.putExtra("pos", index); sendBroadcast(i); finish(); break; [color=red]case ITEM2: /*下面的代码能够删除listview中的音频文件,但是删除之后如何刷新呢?*/ file = new File(_path[index]); if(file.exists()){ file.delete(); } break;[/color] case ITEM3: Intent intent = new Intent(MusicListActivity.this,MusicInfo.class); intent.putExtra("_Name", _name[index]); intent.putExtra("_Size", _size[index]); intent.putExtra("_Singer", _singer[index]); intent.putExtra("_Album", _album[index]); intent.putExtra("_Time", _time[index]); intent.putExtra("_Path", _path[index]); startActivity(intent); System.out.println("Name:"+_name[index]+" Size:"+_size[index]+" Path:"+_path[index]+" Singer:"+_singer[index]+" Album:"+_album[index]+" Time:"+_time[index]); break; default: break; } return super.onContextItemSelected(item); } //添加menu菜单 public boolean onCreateOptionsMenu(Menu menu){ super.onCreateOptionsMenu(menu); menu.add(0,ITEM1,0,"更新列表").setIcon(R.drawable.update_file); menu.add(0,ITEM2,0,"返回").setIcon(R.drawable.menu_exit); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()){ case ITEM1: scanSdCard(); break; case ITEM2: onBackPressed(); break; default: break; } return true; } //扫描本地sdcard卡文件 private void scanSdCard(){ IntentFilter intentfilter = new IntentFilter(Intent.ACTION_MEDIA_SCANNER_STARTED); intentfilter.addAction(Intent.ACTION_MEDIA_SCANNER_FINISHED); intentfilter.addDataScheme("file"); scanSdReceiver = new ScanSdReceiver(); registerReceiver(scanSdReceiver, intentfilter); sendBroadcast(new Intent(Intent.ACTION_MEDIA_MOUNTED,Uri.parse("file://"+Environment.getExternalStorageDirectory().getAbsolutePath()))); } @Override public void onBackPressed() { // TODO Auto-generated method stub if (scanSdReceiver!=null) unregisterReceiver(scanSdReceiver); this.finish(); super.onBackPressed(); } }

安卓实现listview嵌套listview

![图片说明](https://img-ask.csdn.net/upload/201510/26/1445834491_579289.jpg) 点击上面的最上面一项里面listview中的哪个小手机删除的时候把下面那一项里面的listview中的三项都删除了 还有就是前面三项都删了的时候删除第四项的时候下标越界 我的思路是我在删除的时候并不知道我删除的到底是那一大项里面的数据。 求解啊

关于android中listview嵌套spinner的思路

需求:关于课程项目,要做一个能够上下滑动,并且在不同item里有不同内容下拉选项(也可以界面中弹出选项)让我选择的app。 疑问: 1.我看到12年就有关于类似问题的讨论,是不是现在还有比listview嵌套spinner更适合的实现方式?有的话麻烦告知,最好有相关文献推荐。 2.如果就按照这种方法,那就需要两个adapter。我看了网上的一些博客,大多是相同spinner,另外有的思路我看不大懂,希望有涉猎的大神能给些建议,解释清楚些,包括adapter,xml以及class,万分感谢!

关于ListView嵌套ListView,删除里层条目获取外层position的问题。(新人币少,烦请大佬悉心解答:D)

![如图](https://img-ask.csdn.net/upload/201707/11/1499743040_424581.png) 当我准备删除里层item的时候,如何知道外层的position,从而及时刷新适配? 我整体的布局是ListView嵌套ListView;外层ListView的item布局是左TextView右ListView;里层ListView的item是TextView和ImageView。 还有我在第一层ListView的item布局添加了android:descendantFocusability="blocksDescendants"之后,可以获取到那个日期的事件,但是依旧获取不到右边里层ListView的事件,也依旧获取不到外层ListView的position。

android菜鸟求助:ListView点击删除按钮时,总是最后一个item被删除

如题,我的ListView的每个item都有一个删除按钮,但是每次点击按钮后都是删除了最后一个item。 调试后position是正确的,索引是没有问题的,每次删除的都是正确的位置,而且每次item一删除就调用notifyDataSetChanged()去刷新,这个问题困扰好几天了…麻烦大神帮帮忙。 public View getView(final int position, View view, ViewGroup arg2) { // TODO Auto-generated method stub if(view == null){ view = inflater.inflate(R.layout.mission_item, null); SharedPreferences shared_mission = getSharedPreferences("mission", Activity.MODE_PRIVATE); mission_name = (TextView) view.findViewById(R.id.pro_name); mission_add = (TextView) view.findViewById(R.id.pro_add); mission_phone = (TextView) view.findViewById(R.id.pro_phone); mission_name.setText(shared_mission.getString("name", "")); mission_add.setText(shared_mission.getString("address", "")); mission_phone.setText(shared_mission.getString("phone", "")); } Button del = (Button) view.findViewById(R.id.del); del.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View arg0) { arr.remove(position); mission_adapter.notifyDataSetChanged(); } }); //删除按钮 listview.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> arg0, View arg1,final int arg2, long arg3) { Intent intent = new Intent(); intent.setClass(MainActivity.this, MissionInfo.class); startActivity(intent); } }); return view; } }

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

搜狗输入法也在挑战国人的智商!

故事总是一个接着一个到来...上周写完《鲁大师已经彻底沦为一款垃圾流氓软件!》这篇文章之后,鲁大师的市场工作人员就找到了我,希望把这篇文章删除掉。经过一番沟通我先把这篇文章从公号中删除了...

总结了 150 余个神奇网站,你不来瞅瞅吗?

原博客再更新,可能就没了,之后将持续更新本篇博客。

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

优雅的替换if-else语句

场景 日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的很不优雅,尤其是对于我这种有强迫症的程序"猿",看到这么多if-else,脑袋瓜子就嗡嗡的,总想着解锁新姿势:干掉过多的if-else!!!本文将介绍三板斧手段: 优先判断条件,条件不满足的,逻辑及时中断返回; 采用策略模式+工厂模式; 结合注解,锦...

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

2020阿里全球数学大赛:3万名高手、4道题、2天2夜未交卷

阿里巴巴全球数学竞赛( Alibaba Global Mathematics Competition)由马云发起,由中国科学技术协会、阿里巴巴基金会、阿里巴巴达摩院共同举办。大赛不设报名门槛,全世界爱好数学的人都可参与,不论是否出身数学专业、是否投身数学研究。 2020年阿里巴巴达摩院邀请北京大学、剑桥大学、浙江大学等高校的顶尖数学教师组建了出题组。中科院院士、美国艺术与科学院院士、北京国际数学...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

《Oracle Java SE编程自学与面试指南》最佳学习路线图2020年最新版(进大厂必备)

正确选择比瞎努力更重要!

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

正确选择比瞎努力更重要!

都前后端分离了,咱就别做页面跳转了!统统 JSON 交互

文章目录1. 无状态登录1.1 什么是有状态1.2 什么是无状态1.3 如何实现无状态1.4 各自优缺点2. 登录交互2.1 前后端分离的数据交互2.2 登录成功2.3 登录失败3. 未认证处理方案4. 注销登录 这是本系列的第四篇,有小伙伴找不到之前文章,松哥给大家列一个索引出来: 挖一个大坑,Spring Security 开搞! 松哥手把手带你入门 Spring Security,别再问密...

字节跳动面试官竟然问了我JDBC?

轻松等回家通知

面试官:你连SSO都不懂,就别来面试了

大厂竟然要考我SSO,卧槽。

阿里面试官让我用Zk(Zookeeper)实现分布式锁

他可能没想到,我当场手写出来了

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

代码注释如此沙雕,会玩还是你们程序员!

某站后端代码被“开源”,同时刷遍全网的,还有代码里的那些神注释。 我们这才知道,原来程序员个个都是段子手;这么多年来,我们也走过了他们的无数套路… 首先,产品经理,是永远永远吐槽不完的!网友的评论也非常扎心,说看这些代码就像在阅读程序员的日记,每一页都写满了对产品经理的恨。 然后,也要发出直击灵魂的质问:你是尊贵的付费大会员吗? 这不禁让人想起之前某音乐app的穷逼Vip,果然,穷逼在哪里都是...

立即提问
相关内容推荐