我的xml ListView:
<ListView
android:id="@+id/listView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:dividerHeight="0dp"
android:divider="@null"
android:layout_alignParentStart="true"
android:layout_below="@+id/textNamesOfTeams"
android:layout_above="@+id/start"
android:descendantFocusability="afterDescendants"/>
和我的CustomAdapter:
class CustomAdapter extends BaseAdapter {
private Context context;
private String[] rValues = {"R1", "R2", "R3", "R4", "R5", "R6", "R7", "R8", "R9", "R10", "R11", "R12", "R13", "R14", "R15", "R16", "R17", "R18", "R19", "R20", "R21", "R22", "R23", "R24"};
CustomAdapter(Context context) {
this.context = context;
}
@Override
public int getViewTypeCount() {
return getCount();
}
@Override
public int getItemViewType(int position) {
return position;
}
@Override
public int getCount() {
return quantityOfTeam;
}
@Override
public String getItem(int position) {
return names[position] +"\n" + names[position + quantityOfTeam];
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
final ViewHolder holder;
if (convertView == null) {
holder = new ViewHolder();
LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
convertView = inflater.inflate(R.layout.brazylian_item_list, null, true);
names = new String[quantityOfTeam * 2];
holder.editText = convertView.findViewById(R.id.brazItemListEditTextName1);
holder.editText2 = convertView.findViewById(R.id.brazItemListEditTextName2);
holder.textView = convertView.findViewById(R.id.brazItemListtextViewR);
convertView.setTag(holder);
} else {
// the getTag returns the viewHolder object set as a tag to the view
holder = (ViewHolder) convertView.getTag();
}
holder.textView.setText(rValues[position]);
holder.editText.setOnFocusChangeListener(new View.OnFocusChangeListener() {
@Override
public void onFocusChange(View view, boolean b) {
if (!b) {
names[position] = holder.editText.getText().toString();
}
}
});
holder.editText2.setOnFocusChangeListener(new View.OnFocusChangeListener() {
@Override
public void onFocusChange(View view, boolean b) {
if (!b) {
names[position + quantityOfTeam] = holder.editText2.getText().toString();
}
}
});
return convertView;
}
private class ViewHolder {
protected EditText editText;
protected EditText editText2;
protected TextView textView;
}
}
列表项:
<TextView
android:id="@+id/brazItemListtextViewR"
android:layout_width="40dp"
android:layout_height="wrap_content"
android:textSize="20sp"
/>
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:weightSum="2"
android:orientation="horizontal"
android:layout_toEndOf="@+id/brazItemListtextViewR"
>
<EditText
android:id="@+id/brazItemListEditTextName1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:textSize="15sp"
android:background="@drawable/rounded_edittext"
android:layout_marginTop="5dp"
android:maxLength="15"
android:singleLine="true"
android:nextFocusDown="@+id/brazItemListEditTextName2"/>
<EditText
android:id="@+id/brazItemListEditTextName2"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:textSize="15sp"
android:background="@drawable/rounded_edittext"
android:layout_marginTop="5dp"
android:maxLength="15"
android:singleLine="true"
/>
</LinearLayout>
移动到另一个EditText,当在Android上单击“下一个软键”时,我很累,但正如我之前所说的,我可以改变焦点,然后从左到右单击enter。我找不到编辑下一行文本的id。
科特林。
在ListViewAdapter类的fun getView()中,添加lastEditText。setOnKeyListner如下:
lastEditText.setOnKeyListener { v, keyCode, event ->
var setOnKeyListener = false
if (keyCode == KeyEvent.KEYCODE_ENTER && event.action == KeyEvent.ACTION_UP) {
try {
val nextRow = getViewByPosition(position + 1, parent as ListView) as LinearLayout
val nextET = nextRow.findViewById(R.id.firstEditText) as EditText
nextET.isFocusableInTouchMode = true
nextET.requestFocus()
} catch (e: Exception) {
// do nothing
}
setOnKeyListener = true
}
setOnKeyListener
}
在有趣的getView()之后添加有趣的getViewByPotion(),如下所示:
private fun getViewByPosition(pos: Int, listView: ListView): View? {
val firstListItemPosition: Int = listView.firstVisiblePosition
val lastListItemPosition: Int = firstListItemPosition + listView.childCount - 1
return if (pos < firstListItemPosition || pos > lastListItemPosition) {
listView.adapter.getView(pos, null, listView)
} else {
val childIndex = pos + listView.headerViewsCount - firstListItemPosition
listView.getChildAt(childIndex)
}
}
在该行的最后一个Editextview中使用此代码。这对我有用
android:imeOptions="actionNext"
android:nextFocusDown="@+id/nextRowEdittextId"
我正在尝试发送一个经过身份验证的请求,只需点击邮递员。 所以,我有一个名为“Oauth”的请求,我正在使用测试将令牌存储在局部变量中。 我现在要做的是,对于需要承载令牌的任何其他请求,自动运行Oauth请求(从预请求脚本)。 有没有一种方法可以通过单击邮递员按钮来获取访问令牌并发送经过身份验证的请求?
我正在用空手道测试做一些测试。 首先是一个职位,期待一个201和一个位置。 第二,使用位置from response来执行get。 有人知道我怎么用空手道吗? 下面的代码是我的尝试,在许多其他代码之后。 但是我得到了: 我不明白为什么。 [编辑] 经过彼得的建议,我感谢! 打印返回: 08:59:33.610[主]信息网。凭直觉。空手道-[打印][”https://www.test.com/enp
基于名字的虚拟主机 Nginx首先选定由哪一个虚拟主机来处理请求。让我们从一个简单的配置(其中全部3个虚拟主机都在端口*:80上监听)开始: server { listen 80; server_name example.org www.example.org; ... } server { listen 80; server_nam
我正在使用名为“更新人员”的Jmete对HTTP补丁方法请求进行性能测试。这里的情况是更新人员依赖于另一个名为“创建人员”的请求。创建人员将返回一个“人员ID”作为响应,我将使用该ID发送更新请求。所以我不能仅使用更新人员请求进行性能测试。这是我的Jmete测试计划布局: 测试仪测试计划 当我运行测试计划时,两个请求的性能都比单独测试Create Person慢得多。我的问题是: 测试两个超文本传
过滤器类 资源类别
问题内容: 如何在一个HTTP请求中下载多个文件?我的意思是,当您有多个附件时,选择要下载的内容,然后按下载,这样便可以自动下载它们,而不必手动单击每个附件。 我正在使用PHP作为服务器端加密。 问题答案: 它 是 可以发送一个在HTTP响应多: 通常,HTTP与任何其他媒体类型一样对待多部分消息主体:严格作为有效负载。[…] HTTP用户代理应遵循与MIME用户代理在收到多部分类型时相同或相似的