GVKun编程网logo

Android NurReaderView 阅读器 (字符串-.txt文件)(android文本阅读器)

17

在本文中,您将会了解到关于AndroidNurReaderView阅读器的新资讯,同时我们还将为您解释字符串-.txt文件的相关在本文中,我们将带你探索AndroidNurReaderView阅读器的

在本文中,您将会了解到关于Android NurReaderView 阅读器 的新资讯,同时我们还将为您解释字符串-.txt文件的相关在本文中,我们将带你探索Android NurReaderView 阅读器 的奥秘,分析字符串-.txt文件的特点,并给出一些关于AdapterView中不支持android – removeView(View)、Android android.view.ViewRoot$CalledFromWrongThreadException异常的解决方案、android listview addHeaderView 和 addFooterView 的注意事项、Android listview addHeaderView 和 addFooterView 详解的实用技巧。

本文目录一览:

Android NurReaderView 阅读器 (字符串-.txt文件)(android文本阅读器)

Android NurReaderView 阅读器 (字符串-.txt文件)(android文本阅读器)

有些地方还没配置好。2/3天后在更新。。。。

功能

  • 支持字符串和<.txt>文件
  • 文字自动分各个页面
  • 支持从右到左-(从右边开始的语言。比如维吾尔语哈扎克语。。。外国的阿拉伯语等)
  • 支持自定义-toolbar-控制器等(自带了同意控制器)
  • 样式-字体大小-夜间模-进度某页式等



AdapterView中不支持android – removeView(View)

AdapterView中不支持android – removeView(View)

当单击 ImageView时,我想从listView中删除某行.我的清单看起来像这样:

我想要的是当最后一个图像被点击删除该行.这是我的适配器

public class UserItemAdapter extends ArrayAdapter<Photos.Record> {
        private ArrayList<Photos.Record> photos;

        public UserItemAdapter(Context context,int textViewResourceId,ArrayList<Photos.Record> photos) {
            super(context,textViewResourceId,photos);
            this.photos = photos;
        }

        @Override
        public View getView(final int position,View convertView,ViewGroup parent) {
            View v = convertView;


            if (v == null) {
                LayoutInflater vi = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);
                v = vi.inflate(R.layout.photorowlist,null);
                                v.setClickable(true);
                                v.setFocusable(true);
            }

            Photos.Record user = photos.get(position);
            if (user != null) {
                TextView photo_name = (TextView) v.findViewById(R.id.photoname);

                if (photo_name != null) {
                    photo_name.setText(user.photo_name);
                }

            }
                        v.setonClickListener(new OnClickListener() {

                        @Override
                        public void onClick(View view) {
                            //Toast.makeText(view.getContext(),"Clicked",Toast.LENGTH_SHORT).show();

                            ImageView delete_photo = (ImageView) view.findViewById(R.id.deletephoto);
                            delete_photo.setonClickListener(new OnClickListener(){  
                            @Override  
                            public void onClick(View v) {  
                                Toast.makeText(Photos.this,"Delete Button Clicked",Toast.LENGTH_SHORT).show();  
                                listView.removeView(v);
                                myadapter.notifyDataSetChanged();


              }});
                         }

                        });


            return v;
        }
    }

    public class Record {
        public String photo_name;

        public Record(String photo_name) {
            this.photo_name = photo_name;
        }
    }

我试图用这个删除行:

listView.removeView(v);
myadapter.notifyDataSetChanged();

我收到错误:ERROR AndroidRuntime java.lang.UnsupportedOperationException:AdapterView不支持removeView(View)

我的秘密在哪里?任何想法?

解决方法

您不必删除“查看”,而是删除照片列表中的项目.
photos.remove(yourPhoto);
notifyDataSetChanged();

此外,您应该使用ViewHolders,Google中有很多提示.希望这将有助于您.

Android android.view.ViewRoot$CalledFromWrongThreadException异常的解决方案

Android android.view.ViewRoot$CalledFromWrongThreadException异常的解决方案

android.view.ViewRoot$CalledFromWrongThreadException异常的解决方案

在Android平台下,进行多线程编程时,经常需要在主线程之外的一个单独的线程中进行某些处理,然后更新用户界面显示。但是,在主线线程之外的线程中直接更新页面显示的问题是

 

报异常:android.view.ViewRoot$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.

【只有原始创建这个视图层次(view hierachy)的线程才能修改它的视图(view)】

也就是说必须在一般必须在程序的主线程(也就是ui)线程中进行更新界面显示的工作。可以采用下面的方法之一来解决:

法1:

在Activity.onCreate(Bundle savedInstanceState)中创建一个Handler类的实例, 在这个Handler实例的handleMessage回调函数中调用更新界面显示的函数。

/** 
     * 启动线程用来刷新登录提示文字,N秒刷新一次 
     *  
     */  
    private class FreshWordsThread extends Thread  
    {  
        @Override  
        public void run()  
        {  
            try  
            {  
                mLoadingWords = "test";  
                mLoadhandler.sendEmptyMessage(REFRESH);  
            }  
            catch (InterruptedException e)  
            {  
                e.printStackTrace();  
                Thread.currentThread().interrupt();  
            }  
        }  
    }  
  
  
  
    //主线程中的handler  
    class LoadHandler extends Handler  
    {  
        /** 
         * 接受子线程传递的消息机制 
         */  
        @Override  
        public void handleMessage(Message msg)  
        {  
            super.handleMessage(msg);  
            int what = msg.what;  
  
            Log.i(TAG, "Main handler message code: " + what);  
            switch (what)  
            {                  
                case REFRESH:  
                {  
                    // 刷新页面的文字  
                    mLoadingText.setText(mLoadingWords);  
                    break;  
                }  
  
            }  
        }  
        
    }  

法2:利用Activity.runOnUiThread(Runnable)把更新ui的代码创建在Runnable中,然后在需要更新ui时,把这个Runnable对象传给Activity.runOnUiThread(Runnable)。 这样Runnable对像就能在ui程序中被调用。

FusionField.currentActivity.runOnUiThread(new Runnable() {  
	public void run() {  
		Toast.makeText(FusionField.currentActivity, "Success", Toast.LENGTH_LONG).show();  
	}  
}); 

 

android listview addHeaderView 和 addFooterView 的注意事项

android listview addHeaderView 和 addFooterView 的注意事项

今天在做项目的时候用了自定义 listview 以及自定义的 item、adapter。现在把其中需要注意的地方记录下来:

1、item 内如果有 button 等控件时,在监听 listview 的 onitemclick 事件时,焦点会被 item 内的 button、imagebutton 等控件抢走,从而导致在 listview 设置了 onitemclick 事件后不会被触发。解决方法是在初始化 item 的时候屏蔽掉其内部 button 等控件的焦点获取,具体方法可以在自定义 item 的根控件中调用:

  setDescendantFocusability(ViewGroup.FOCUS_BLOCK_DESCENDANTS);

这样就能阻塞字控件抢夺焦点,listview 的 onitemclick 就能被正确触发,同时对 item 内部的 button 等控件也没有影响,他们在被点击时照样可以触发自身的点击事件。


2、当 listview 需要添加 headerview 时,可以通过调用 listview 的 addHeaderView (headView, null, false) 方法,该方法还有一个重载方法 addHeaderView (headView); 这两个方法的区别是前一个方法可以控制 header 是否可以被 selected,如果不想被 selected 则将第三个参数设置成 false;


3、接着上面说的添加 header,添加 header 时调用的 addHeaderView 方法必须放在 listview.setadapter 前面,意思很明确就是如果想给 listview 添加头部则必须在给其绑定 adapter 前添加,否则会报错。原因是当我们在调用 setAdapter 方法时会 android 会判断当前 listview 是否已经添加 header,如果已经添加则会生成一个新的 HeaderViewListAdapter,这个新的 HeaderViewListAdapter 包含我们设置的 adapter 所有内容以及 listview 的 header 和 footer。所以当我们在给 listview 添加了 header 后在程序中调用 listview.getadapter 时返回的是 tempadapter 而不是我们通过 setadapter 传进去的 adapter。如果没有设置 adapter 则 HeaderViewListAdapter 与我们自己的 adapter 是一样的。listview.getadapter ().getcount () 方法返回值会比我们预期的要大,原因是添加了 header。


4、接着上面的 HeaderViewListAdapter 说,我们自定义 adapter 里面的 getitem 方法里面返回的 position 是不包括 header 的,是我们自定义 adapter 中数据 position 编号从 0 开始,也就是说与我们传进去的 list 的位置是一样的。

  • @Override

  • public View getView(int position, View convertView, ViewGroup parent) {

  • // TODO Auto-generated method stub

  • Log.i ("adapter", "position:"+position); // 这个 position 就是我们数据的真实位置

  • }

而 listview 的 onitemclick 方法中:

public void onItemSelected(AdapterView<?> parent, View view, int position, long id)

position 是当前 click 的位置,这个位置是指在 HeaderViewListAdapter 中的位置,从 0 开始如果 listview 中添加了 header 则 0 代表 header。


Android listview addHeaderView 和 addFooterView 详解

Android listview addHeaderView 和 addFooterView 详解

addHeaderView()方法:主要是向listView的头部添加布局
addFooterView()方法:主要是向listView的底部添加布局

需要注意的是添加布局的时候应该添加从父容器开始添加,而不能直接添加父容器中的子控件。例如:从一个xml布局文件中添加一个button控件,
只能将整个布局xml文件添加进去。而不能单单只添加button控件。

当添加头部和底部布局还有另外一个重载方法就是addHeaderView(headView, null, false) 和addFooterView(footerView, null, false)方法,
这个方法与上面的方法区别在于:当给listView设置点击事件的时候,可以控制添加的布局是否可出发点击事件。区别是前一个方法可以控制header是否可
 以被selected,如果不想被selected则将第三个参数设置成false;

下面以addFooterView()方法为例:
addFooterView()方法必须放在listview.setadapter前面,给listview添加头部必须在绑定adapter前添加,否则会报错。
原因是当我们在调用setAdapter方法时android会判断当前listview是否已经添加header,如果已经添加则会生成一个
 新的tempadapter,这个新的tempadapter包含我们设置的adapter所有内容以及listview的header和footer。所以当我

们在给listview添加了header后在程序中调用listview.getadapter时返回的是tempadapter而不是我们通过setadapter

传进去的adapter。如果没有设置adapter则tempadapter与我们自己的adapter是一样的。
  listview.getadapter().getcount()方法返回值会比我们预期的要大,原因是添加了header。
  我们自定义adapter里面的getitem方法里面返回的position是不包括header的,是我们自定义adapter中数据position编号从0开始,
  也就是说与我们传进去的list的位置是一样的。
  而Activity中listview的onitemclick方法:
  public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,long arg3)
  arg2是当前click的位置,这个位置是指在tempadapter中的位置,从0开始如果listview中添加了header则0代表header。
  也就是说当我们在使用点击事件时,listView列中的位置为arg2-1
  
  一般在开发中,为了达到我们想要的动态添加的效果主要的做法是:在listview.setadapter之前添加所需要的控件,然后使用removeFooterView()方法移除控件。
  在这里需要注意的是,每对listView的动态操作都要进行一次removeFooterView()方法移除控件。否则listView会自动添加空白行,从而影响显示的效果。
 ----------------------------------------------------------------------------------------------

android listview addHeaderView和addFooterView的注意事项  :

1、item 内如果有button等控件时,在监听listview的onitemclick事件时,焦点会被item内的button、imagebutton等控 件抢走,
从而导致在listview设置了onitemclick事件后不会被触发。解决方法是在初始化item的时候屏蔽掉其内部button等控件的 焦点获取,
具体方法可以在自定义item的根控件中调用:

 setDescendantFocusability(ViewGroup.FOCUS_BLOCK_DESCENDANTS); 
这样就能阻塞字控件抢夺焦点,listview的onitemclick就能被正确触发,同时对item内部的button等控件也没有影响,他们在被点击时照样可以触发自身的点击事件。
 
2、当listview需要添加headerview时,可以通过调 用listview的addHeaderView(headView, null, false) 方法,
该方法还有一个重载方法 addHeaderView(headView);这两个方法的区别是前一个方法可以控制header是否可以被selected,如果不想被 selected则将第三个参数设置成false 
  
3、接着上面说的添加header,添加header时调用的 addHeaderView方法必须放在listview.setadapter前面,
意思很明确就是如果想给listview添加头部则必须在给其绑定 adapter前添加,否则会报错。
原因是当我们在调用setAdapter方法时会android会判断当前listview是否已经添加 header,
如果已经添加则会生成一个新的HeaderViewListAdapter,这个新的HeaderViewListAdapter包含我们 设置的adapter所有内容以及listview的header和footer。
所以当我们在给listview添加了header后在程序中调用 listview.getadapter时返回的是tempadapter而不是我们通过setadapter传进去的adapter。
如果没有设置 adapter则HeaderViewListAdapter与我们自己的adapter是一样的。 listview.getadapter().getcount()方法返回值会比我们预期的要大,原因是添加了header。

4、接着上面的HeaderViewListAdapter说,我们 自定义adapter里面的getitem方法里面返回的position是不包括header的,是我们自定义adapter中数据position编 号从0开始,也就是说与我们传进去的list的位置是一样的。

 

@Override

public View getView(int position, View convertView, ViewGroup parent) {

// TODO Auto-generated method stub

Log.i("adapter", "position:"+position); //这个position就是我们数据的真实位置

}

而listview的onitemclick方法中:

public void onItemSelected(AdapterView<?> parent, View view, int position, long id)

position是当前click的位置,这个位置是指在HeaderViewListAdapter中的位置,从0开始如果listview中添加了header则0代表header。4、接着上面的HeaderViewListAdapter说,我们 自定义adapter里面的getitem方法里面返回的position是不包括header的,是我们自定义adapter中数据position编 号从0开始,也就是说与我们传进去的list的位置是一样的。


public View getView(int position, View convertView, ViewGroup parent) {

// TODO Auto-generated method stub

Log.i("adapter", "position:"+position); //这个position就是我们数据的真实位置

}

而listview的onitemclick方法中:

public void onItemSelected(AdapterView<?> parent, View view, int position, long id)

position是当前click的位置,这个位置是指在HeaderViewListAdapter中的位置,从0开始如果listview中添加了header则0代表header。

 

 关于FooterView的添加和删除
 *   3.1每次总是先remove掉FooterView
 *   3.2若有需求再add上FooterView

 
 
 我们通常在加载数据时,为了省流量不会一次性把数据全部下完,一般是分段下载。
 分段下载一般会在listview最后面放一个进度条表示正在加载数据,当数据加载完时,我们又要清除它。这时候就要注意了。
mLoadingLayout = (FrameLayout) View.inflate(this, R.layout.load, null);
   listView.addFooterView(mLoadingLayout);
   listView.requestFocus();

这是listview尾部添加一个进度条。
listView.removeFooterView(mLoadingLayout);
这是移除尾部的进度条。
有时候在移除时回报空指针,但listview不为null ,mLoadingLayout也不为null,但还是报空指针,原因是因为listview要分为三部分。
一是头部,二是中间部,三是尾部。在设置了头部或尾部时,必须要有中间部才能真正意义上的生效。没生效就去移除就会报空指针错误。
所以在 
listView.removeFooterView(mLoadingLayout);时

必须先调用 listView.setAdapter(adapter);(设置中间部)

adapter可以数据可以为0但不可为null

今天的关于Android NurReaderView 阅读器 字符串-.txt文件的分享已经结束,谢谢您的关注,如果想了解更多关于AdapterView中不支持android – removeView(View)、Android android.view.ViewRoot$CalledFromWrongThreadException异常的解决方案、android listview addHeaderView 和 addFooterView 的注意事项、Android listview addHeaderView 和 addFooterView 详解的相关知识,请在本站进行查询。

本文标签: