- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 EditContact
类。打开后,它会显示哪些复选框已选中或未选中。这是通过我的适配器
中的一些代码完成的,它可以正常工作:
//This is for EditContact, to display checked checkboxes. Numbers not in the array will remain unchecked.
//for every phone number in the checkedContactsAsArrayList array list...
for (int number2 = 0; number2 < checkedContactsAsArrayList.size(); number2++) {
Log.i("MyMessage","checkedContactsAsArrayList is: " + checkedContactsAsArrayList);
//if a phone number is in our array of checked contacts
if (checkedContactsAsArrayList.contains(selectPhoneContact.getPhone())) {
//check the box
((MatchingContact) viewHolder).check.setChecked(true);
}
}
在我的 EditContact
类中,用户可以选中或取消选中联系人列表中的框。如果选中它们,则应保存它们,并且适配器中的代码应反射(reflect)新的checkedContactsAsArrayList,但无论选中什么,它始终会保存为空。
在System.out
中,我可以看到我们处于尝试部分
,然后它直接进入EditContact:不幸的是,这里有一个问题
。您能告诉我出了什么问题以及如何解决吗?
这是我的保存
按钮的代码:
//for the SAVE button
private void saveContactButton() {
save.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
System.out.println("you clicked it, save");
//close the class
//(we'll be opening it again, will close now so it will be refreshed)
PopulistoListView.fa.finish();
pDialog = new ProgressDialog(EditContact.this);
// Showing progress dialog for the review being saved
pDialog.setMessage("Saving...");
pDialog.show();
try {
System.out.println("we're in the try part");
//the user will be able to check contacts who to share the review
// with, from their matching contacts list
int count = PopulistoContactsAdapter.MatchingContactsAsArrayList.size();
for (int i = 0; i < count; i++) {
LinearLayout itemLayout = (LinearLayout)recyclerView.getChildAt(i);
CheckBox checkbox = (CheckBox)itemLayout.findViewById(R.id.checkBoxContact);
SelectPhoneContact contact = (SelectPhoneContact) checkbox.getTag();
// make each checked contact in selectPhoneContacts
// into an individual
// JSON object called checkedContact
JSONObject checkedContact = new JSONObject();
//if that checkbox is checked, then get the phone number
if(checkbox.isChecked()) {
// checkedContact will be of the form {"checkedContact":"+353123456"}
checkedContact.put("checkedContact", contact.getPhone());
// Add checkedContact JSON Object to checkedContacts jsonArray
//The JSON Array will be of the form
// [{"checkedContact":"+3531234567"},{"checkedContact":"+353868132813"}]
//we will be posting this JSON Array to Php, further down below
checkedContacts.put(checkedContact);
System.out.println("EditContact: checkedcontact JSONObject :" + checkedContact);
}
}
System.out.println("checkedContacts JSON Array " + checkedContacts);
} catch (Exception e) {
System.out.println("EditContact: there's a problem here unfortunately");
e.printStackTrace();
}
//post the review_id in the current activity to EditContact.php and from that
//get associated values - category, name, phone etc...
StringRequest stringRequest = new StringRequest(Request.Method.POST, EditContact_URL,
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Toast.makeText(EditContact.this, response, Toast.LENGTH_LONG).show();
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(EditContact.this, "there's a problem saving this page", Toast.LENGTH_LONG).show();
}
}) {
protected Map<String, String> getParams() {
Map<String, String> params = new HashMap<String, String>();
//post the phone number to php to get the user_id in the user table
params.put("phonenumberofuser", phoneNoofUserCheck);
params.put("review_id", review_id);
//the second value, categoryname.getText().toString() etc...
// is the value we get from Android.
//the key is "category", "name" etc.
// When we see these in our php, $_POST["category"],
//put in the value from Android
params.put("category", categoryname.getText().toString());
params.put("name", namename.getText().toString());
params.put("phone", phonename.getText().toString());
params.put("address", addressname.getText().toString());
params.put("comment", commentname.getText().toString());
params.put("public_or_private", String.valueOf(pub_or_priv));
//this is the JSON Array of checked contacts
//it will be of the form
//[{"checkedContact":"+3531234567"},{"checkedContact":"+353868132813"}]
params.put("checkedContacts", checkedContacts.toString());
return params;
}
};
AppController.getInstance().addToRequestQueue(stringRequest);
//when saved, go to the PopulistoListView class and update with
//the edited values
Intent j = new Intent(EditContact.this, PopulistoListView.class);
EditContact.this.startActivity(j);
finish();
//hide the dialogue box when page is saved
hidePDialog();
}
});
}
在 logcat
中不幸的是
下面有一个问题,它说:
java.lang.ClassCastException:java.lang.Integer 无法转换为 com.example.chris.tutorialspoint.SelectPhoneContact
,位于 第 318 行
,即
SelectPhoneContact contact = (SelectPhoneContact) checkbox.getTag();
但不知道如何修复它。
在我的适配器
的onBindViewHolder
中:
//if the activity is EditContact
if (whichactivity == 2) {
//if the row is a matching contact
if (viewHolder.getItemViewType() == 1)
{
//in the title textbox in the row, put the corresponding name etc...
((MatchingContact) viewHolder).title.setText(selectPhoneContact.getName());
((MatchingContact) viewHolder).phone.setText(selectPhoneContact.getPhone());
((MatchingContact) viewHolder).check.setChecked(theContactsList.get(position).getSelected());
((MatchingContact) viewHolder).check.setTag(position);
//disable the check box, can't be changed
//((MatchingContact) viewHolder).check.setEnabled(false);
((MatchingContact) viewHolder).check.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//pos is the row number that the clicked checkbox exists in
Integer pos = (Integer) ((MatchingContact) viewHolder).check.getTag();
//NEED THIS TO PRESERVE CHECKBOX STATE
if (theContactsList.get(pos).getSelected()) {
theContactsList.get(pos).setSelected(false);
Toast.makeText(context_type, theContactsList.get(pos).getPhone() + " unclicked!", Toast.LENGTH_SHORT).show();
} else {
theContactsList.get(pos).setSelected(true);
Toast.makeText(context_type, theContactsList.get(pos).getPhone() + " clicked!", Toast.LENGTH_SHORT).show();
}
//we want to keep track of checked boxes, so when it is '0'
//'Phone Contacts' button will switch to 'Just Me'
int count;
count = 0;
int size = theContactsList.size();
for (int i = 0; i < size; i++) {
if (theContactsList.get(i).isSelected) {
count++;
// System.out.println("The count is " + count);
}
}
Log.i("MyMessage", "The count is " + count);
}
});
} else {
((nonMatchingContact) viewHolder).title.setText(selectPhoneContact.getName());
((nonMatchingContact) viewHolder).phone.setText(selectPhoneContact.getPhone());
}
//This is for EditContact, to display the contact the review is shared with
//for every phone number in the checkedContactsAsArrayList array list...
for (int number2 = 0; number2 < checkedContactsAsArrayList.size(); number2++) {
Log.i("MyMessage","checkedContactsAsArrayList is: " + checkedContactsAsArrayList);
//if a phone number is in our array of checked contacts
if (checkedContactsAsArrayList.contains(selectPhoneContact.getPhone())) {
//check the box
((MatchingContact) viewHolder).check.setChecked(true);
}
}
}
还有我的SelectPhoneContact
类:
public class SelectPhoneContact {
String phone;
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
boolean isMatching;
public boolean isMatching(){return isMatching;}
public void setIsMatchingContact(boolean isMatching){
this.isMatching = isMatching;
}
//*****************************************
//this is for the checkbox
//by default, make it unchecked
boolean isSelected = false;
public boolean getSelected() {
return isSelected;
}
public void setSelected(boolean selected){
isSelected = selected;
}
String type_row;
public String getType_row() {
return type_row;
}
public void setType_row(String type_row) {
this.type_row = type_row;
}
}
最佳答案
问题是您将整数设置为标签:
((MatchingContact) viewHolder).check.setTag(position);
然后在获取它时将其转换为 SelectPhoneContact 类型的对象:
SelectPhoneContact contact = (SelectPhoneContact) checkbox.getTag();
也许你可以尝试这样的事情:
Object position = checkbox.getTag();
if (position instanceof Integer) {
SelectPhoneContact contact = checkedContactsAsArrayList.get((Integer)position);
}
关于java - ClassCastException,为什么我的保存按钮在单击时没有将选中的复选框保存到我的数据库中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48813332/
我的问题是如何在 python 中创建一个简单的数据库。我的例子是: User = { 'Name' : {'Firstname', 'Lastname'}, 'Address' : {'Street
我需要创建一个与远程数据库链接的应用程序! mysql 是最好的解决方案吗? Sqlite 是唯一的本地解决方案吗? 我使用下面的方法,我想知道它是否是最好的方法! NSString *evento
给定两台 MySQL 服务器,一台本地,一台远程。两者都有一个包含表 bohica 的数据库 foobar。本地服务器定义了用户 'myadmin'@'%' 和 'myadmin'@'localhos
我有以下灵活的搜索查询 Select {vt:code},{vt:productcode},{vw:code},{vw:productcode} from {abcd AS vt JOIN wxyz
好吧,我的电脑开始运行有点缓慢,所以我重置了 Windows,保留了我的文件。因为我的大脑还没有打开,所以我忘记事先备份我的 MySQL 数据库。我仍然拥有所有原始文件,因此我实际上仍然拥有数据库,但
如何将我的 Access 数据库 (.accdb) 转换为 SQLite 数据库 (.sqlite)? 请,任何帮助将不胜感激。 最佳答案 1)如果要转换 db 的结构,则应使用任何 DB 建模工具:
系统检查发现了一些问题: 警告:?:(mysql.W002)未为数据库连接“默认”设置 MySQL 严格模式 提示:MySQL 的严格模式通过将警告升级为错误来修复 MySQL 中的许多数据完整性问题
系统检查发现了一些问题: 警告:?:(mysql.W002)未为数据库连接“默认”设置 MySQL 严格模式 提示:MySQL 的严格模式通过将警告升级为错误来修复 MySQL 中的许多数据完整性问题
我想在相同的 phonegap 应用程序中使用 android 数据库。 更多说明: 我创建了 phonegap 应用程序,但 phonegap 应用程序不支持服务,所以我们已经在 java 中为 a
Time Tracker function clock() { var mytime = new Date(); var seconds
我需要在现有项目上实现一些事件的显示。我无法更改数据库结构。 在我的 Controller 中,我(从 ajax 请求)传递了一个时间戳,并且我需要显示之前的 8 个事件。因此,如果时间戳是(转换后)
我有一个可以收集和显示各种测量值的产品(不会详细介绍)。正如人们所期望的那样,显示部分是一个数据库+建立在其之上的网站(使用 Symfony)。 但是,我们可能还会创建一个 API 来向第三方公开数据
我们将 SQL Server 从 Azure VM 迁移到 Azure SQL 数据库。 Azure VM 为 DS2_V2、2 核、7GB RAM、最大 6400 IOPS Azure SQL 数据
我正在开发一个使用 MongoDB 数据库的程序,但我想问在通过 Java 执行 SQL 时是否可以使用内部数据库进行测试,例如 H2? 最佳答案 你可以尝试使用Testcontainers Test
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 已关闭 9 年前。 此问题似乎与 a specific programming problem, a sof
我正在尝试使用 MSI 身份验证(无需用户名和密码)从 Azure 机器学习服务连接 Azure SQL 数据库。 我正在尝试在 Azure 机器学习服务上建立机器学习模型,目的是我需要数据,这就是我
我在我的 MySQL 数据库中使用这个查询来查找 my_column 不为空的所有行: SELECT * FROM my_table WHERE my_column != ""; 不幸的是,许多行在
我有那个基地:http://sqlfiddle.com/#!2/e5a24/2这是 WordPress 默认模式的简写。我已经删除了该示例不需要的字段。 如您所见,我的结果是“类别 1”的两倍。我喜欢
我有一张这样的 table : mysql> select * from users; +--------+----------+------------+-----------+ | userid
我有表: CREATE TABLE IF NOT EXISTS `category` ( `id` int(11) NOT NULL, `name` varchar(255) NOT NULL
我是一名优秀的程序员,十分优秀!