- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
此图说明了我的 Activity 的复杂性。有多个(本例中为 3 层) fragment 需要动态加载。重复 fragment 是使用 LinearListView 加载的,这是我在这里找到的一个 View 库:https://github.com/frankiesardo/LinearListView 。这允许列表像 ListView 一样加载,但避免了在 ScrollView 中包含 ListView 的问题。
以下是一些示例代码:
line_item_list.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/line_item_list">
<TextView
android:layout_width="171dp"
android:layout_height="wrap_content"
android:text="LineItem List"
android:id="@+id/line_item_list_text" />
<com.linearlistview.LinearListView
android:id="@+id/line_item_wrapper"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:divider="#f00"
android:orientation="vertical"
android:showDividers="middle"
app:dividerThickness="16dp"
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/tools"/>
</LinearLayout>
line_item.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/line_item">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="my line item."
android:id="@+id/line_item_text"
android:layout_gravity="center_horizontal" />
<!-- notes child items go here -->
</LinearLayout>
LineItemFragment.java 使用适配器加载 fragment (此代码中的 lineItem 在上图中显示为“Part”一词。)
public class LineItemFragment extends Fragment {
LineItemAdapter adapter;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
LinearListView lineItems = (LinearListView)container.findViewById(R.id.line_item_wrapper);
adapter = new LineItemAdapter(this.getContext(), getChildFragmentManager());
lineItems.setAdapter(adapter);
return null;
}
}
LineItemAdapter.java
public class LineItemAdapter extends BaseAdapter{
ArrayList<String> lineItems = new ArrayList<String>();
Context context;
FragmentManager fm;
public LineItemAdapter(Context context, FragmentManager fragmentManager) {
this.context = context;
lineItems.add("Item A");
lineItems.add("Item B");
lineItems.add("Item C");
this.fm = fragmentManager;
}
@Override
public int getCount() {
return lineItems.size();
}
@Override
public Object getItem(int position) {
return lineItems.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if (convertView == null) {
convertView = ((LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE))
.inflate(R.layout.line_item, parent, false);
}
((TextView)convertView.findViewById(R.id.line_item_text)).setText(getItem(position).toString());
// *** The getView method could load the child fragments
return convertView;
}
}
在上一个文件(***)中,我当前认为 getView 方法应该加载下一级子 fragment ,但我尝试过的一切都不起作用。布局似乎尚未膨胀,因此我无法向其中添加 subview 。
我的问题是,“如何从 getView 中添加子 fragment ?”或者也许我的做法是错误的。
这是我尝试过的一个示例:
lineItemAdapter.java 中的 getView 方法(***):
.
.
.
LinearLayout notes = (LinearLayout) ((LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE))
.inflate(R.layout.line_item, parent, false);
LinearLayout b = (LinearLayout)((LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE))
.inflate(R.layout.note_list, notes).getRootView();
NoteListFragment noteListFragment = new NoteListFragment();
fm.beginTransaction().add(b.getId(), noteListFragment).commit();
.
.
.
我遇到了这样的异常。
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.myapplication, PID: 12207
java.lang.RuntimeException: Unable to start activity
ComponentInfo{com.example.myapplication/com.example.myapplication.DetailActivity}: java.lang.IllegalStateException: Fragment does not have a view
at
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2416)
at
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
.
.
.
提前致谢。
编辑
我需要在 xml 中添加一个 fragment 吗,即:
line_item.xml...新节点:
<fragment android:name="com.example.noteListFragment"
android:id="@+id/note_list_fragment"
android:layout_weight="1"
android:layout_width="0dp"
android:layout_height="wrap_content" />
最佳答案
最后,我出于此目的放弃了 fragment ,并删除了通货膨胀代码。相反,我加载包含在 xml 中的相同布局结构,因此我不必构建比已有的更大的 xml 文件。
对于我要放入 fragment 中的功能,我放入了演示者类,然后使用 ButterKnife 的 View 注入(inject)将演示者绑定(bind)到 View 中的适当级别。
我仍在研究使用事件总线在各层之间进行通信,如 @mt0s 建议的那样。
如果您想朝这个方向发展,这里有一些代码可以帮助您:
使用 include,我可以将整个结构整合在一起,将每个层布局保留在自己的 xml 文件中:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_workorder"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
>
<LinearLayout
android:id="@+id/workorder_detail_container"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<include layout="@layout/workorder_header"/> <!-- include other layouts -->
<include layout="@layout/workorder_service_items"/>
</LinearLayout>
</LinearLayout>
接下来,我创建了一个 Presenter.class 文件来设置适配器,使用 ButterKnife 绑定(bind)到 View 的该部分:
public class WorkOrderPresenter implements PropertyChangeListener
{
private View detailView;
private WorkOrder workOrder; // the object to display
private List<WorkorderAsset> assetList;
// Set your bindings to the view, passing the id from the layout.
@Bind(R.id.workorderasset_list) View serviceItemDetail;
@Bind(R.id.workorderasset_list_content) LinearListView assets;
@Bind(R.id.number_of_service_items) TextView numberOfServiceItems;
@Bind(R.id.total_value) TextView totalView;
WorkOrderAssetAdapter workOrderAssetAdapter; // an adapter for a child list
// Constructor
public WorkOrderPresenter(View view, WorkOrder wo, final Activity activity)
{
workOrder = wo;
detailView = view;
ButterKnife.bind(this, detailView); //this is where the binding actually happens
workOrderAssetContent = Provider.GetItems // Load you items for the adapter.
// My system gives items back asynchronously:
workOrderAssetContent.getWorkOrderAssets(workOrder.getWorkOrderID(), new iProvideCallback<List<WorkorderAsset>>() {
@Override
public void onSuccess(iResponse<List<WorkorderAsset>> response) {
assetList = response.getResponse();
numberOfServiceItems.setText(String.valueOf(assetList.size()));
workOrderAssetAdapter = new WorkOrderAssetAdapter(activity, assetList); // construct the adapter with items.
assets.setAdapter(workOrderAssetAdapter);
}
@Override
public void onFailure(iResponse<List<WorkorderAsset>> response) {
Toast.makeText(activity.getApplicationContext(), R.string.ServiceItemsError, Toast.LENGTH_LONG);
}
});
}
}
这是一个用于显示项目的适配器:
public class WorkOrderAssetAdapter extends BaseAdapter
{
private Activity activity;
private List<WorkorderAsset> workorderAssetList;
private static LayoutInflater inflater = null;
// Constructor
public WorkOrderAssetAdapter(Activity a, List<WorkorderAsset> items)
{
workorderAssetList = items;
activity = a;
inflater = LayoutInflater.from(activity);
}
@Override
public int getCount() { return workorderAssetList.size(); }
@Override
public Object getItem(int position) { return workorderAssetList.get(position); }
@Override
public long getItemId(int position) { return position; }
// view holder for the item
public static class ViewHolder extends WorkOrderAssetViewHolder
{
@Bind(R.id.line_item_text) TextView line_item_text;
@Bind(R.id.line_item_list) LinearListView list;
// Adapter, Data Provider and Presenter for the next level.
public WorkOrderAssetLineItemAdapter adapter;
public WorkOrderAssetLineItemProvider provider;
public WorkOrderAssetLineItemPresenter presenter;
private Activity activity;
private WorkorderAsset workOrderAsset;
public VehicleViewHolder(WorkorderAsset asset, final View view, Activity activity_in)
{
ButterKnife.bind(this, view);
workOrderAsset = asset;
activity = activity_in;
workOrderAssetLineItemContent = new WorkOrderAssetLineItemContent(((RoadFS)activity.getApplication()).getServer(), ((RoadFS)activity.getApplication()).getApplicationContext());
workOrderAssetLineItemContent.getWorkOrderAssetLineItems(
workOrderAsset.getWorkOrderID(),
workOrderAsset.getWorkOrderAssetID(),
new iProvideCallback<List<WorkorderAssetLineItem>>() {
@Override
public void onSuccess(iResponse response) {
list.setAdapter(new WorkOrderAssetLineItemAdapter(activity,
(List<WorkorderAssetLineItem>) response.getResponse(),
view));
}
@Override
public void onFailure(iResponse response) {
}
});
}
@Override
public View getView(final int position, View view, ViewGroup parent)
{
WorkorderAsset workOrderAsset;
workOrderAsset = workorderAssetList.get(position);
ViewHolder holder;
if (view != null) {
holder = (ViewHolder) view.getTag();
} else {
view = inflater.inflate(R.layout.workorder_detail_workorderasset_vehicle, parent, false);
holder = new VehicleViewHolder(workOrderAsset, view, activity);
view.setTag(holder);
}
holder.item_text.setText(workOrderAsset.getVIN());
holder.workOrderAssetLineItemContent = new WorkOrderAssetLineItemContent(((RoadFS) activity.getApplication()).getServer(), activity);
holder.workOrderAssetLineItemAdapter = new WorkOrderAssetLineItemAdapter(activity, WorkOrderAssetLineItemContent.workorderAssetLineItemList, view);
return view;
}
}
这个例子有点不完整,我还没有示例项目,但希望它能帮助别人。它没有按预期回答问题,但尝试了两种方法后,我认为这是一个更好的解决方案,因为它比处理 fragment 的复杂性更简单。 fragment 仍将用于更改屏幕大小/方向,但 fragment 不会用于复杂的布局。感谢您的任何意见。
关于java - 如何使用 BaseAdapter 将子 fragment 添加到 Android 中的 fragment ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35448844/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!