Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/187.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android onClickListener在第二个活动中不起作用_Android_Android Activity_Onclicklistener - Fatal编程技术网

Android onClickListener在第二个活动中不起作用

Android onClickListener在第二个活动中不起作用,android,android-activity,onclicklistener,Android,Android Activity,Onclicklistener,我得到了一个活动,它是从主活动中调用的。在活动中,我建立了数据库连接,并根据数据库数据填充微调器。当用户选择一个微调器项并按下按钮时,“活动”完成并向主活动返回一个值(“结果时的活动”)。但是活动中的按钮不起作用,因此活动从不向主活动返回值。代码如下: import java.io.Serializable; import java.util.ArrayList; import java.util.List; import android.app.Activity; import androi

我得到了一个活动,它是从主活动中调用的。在活动中,我建立了数据库连接,并根据数据库数据填充微调器。当用户选择一个微调器项并按下按钮时,“活动”完成并向主活动返回一个值(“结果时的活动”)。但是活动中的按钮不起作用,因此活动从不向主活动返回值。代码如下:

import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;

import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.Spinner;
import android.widget.Toast;

public class mySpinnerClass extends Activity implements
        OnItemSelectedListener {

    private VeriTabani veritabani;
    private SQLiteDatabase db;

    Spinner spinner;

    Button btnAdd;

    String dataBaseName;
    int selectedValue;

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.spinner);

        dataBaseName = "";
        selectedValue = -1;

        Intent i = getIntent();
        dataBaseName = i.getStringExtra("dataBaseName");

        veritabani = new VeriTabani(this);
        db = veritabani.getWritableDatabase();

        // Spinner element
        spinner = (Spinner) findViewById(R.id.mySpinner);

        // add button
        btnAdd = (Button) findViewById(R.id.addButton);

        // Spinner click listener
        spinner.setOnItemSelectedListener(this);

        // Loading spinner data from database
        loadSpinnerData();


        btnAdd.setOnClickListener(new View.OnClickListener() {

            public void onClick(View arg0) {

                    if (dataBaseName == "phoneOrientation") {
                        Intent intent = getIntent();
                        intent.putExtra("phoneOrientation", selectedValue);
                        setResult(RESULT_OK, intent);
                        finish();

                    }
                    else if(dataBaseName== "phonePosition") {
                        Intent intent = getIntent();
                        intent.putExtra("phonePosition", selectedValue);
                        setResult(RESULT_OK, intent);
                        finish();
                    }
                    else if(dataBaseName =="Label"){
                        Intent intent=getIntent();
                        intent.putExtra("label",selectedValue);
                        setResult(RESULT_OK, intent);
                        finish();
                    }


            }
        });
    }

    private void loadSpinnerData() {

        // Spinner Drop down elements
        List<String> lables = getAllLabels();

        // Creating adapter for spinner
        ArrayAdapter<String> dataAdapter = new ArrayAdapter<String>(this,
                android.R.layout.simple_spinner_item, lables);

        // Drop down layout style - list view with radio button
        dataAdapter
                .setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

        // attaching data adapter to spinner
        spinner.setAdapter(dataAdapter);
    }

    public List<String> getAllLabels() {
        List<String> labels = new ArrayList<String>();

        // Select All Query
        String selectQuery = "SELECT  * FROM " + dataBaseName;

        Cursor cursor = db.rawQuery(selectQuery, null);

        // looping through all rows and adding to list
        if (cursor.moveToFirst()) {
            do {
                labels.add(cursor.getString(cursor.getColumnIndex("isim")));
            } while (cursor.moveToNext());
        }

        // closing connection

        // returning lables
        return labels;
    }

    public int returnID(String item) {
        int toBereturnedID;
        Cursor myCursor = db.rawQuery("SELECT _id from " +dataBaseName+ " WHERE isim="+"'"+item+"'", null);
        myCursor.moveToFirst();
        toBereturnedID = myCursor.getInt(0);
        return toBereturnedID;
    }

    public void onItemSelected(AdapterView<?> parent, View arg1, int position, long arg3) {
        // TODO Auto-generated method stub
        String label = parent.getItemAtPosition(position).toString();
        selectedValue = returnID(label);
    }

    public void onNothingSelected(AdapterView<?> arg0) {
        // TODO Auto-generated method stub

    }

}
import java.io.Serializable;
导入java.util.ArrayList;
导入java.util.List;
导入android.app.Activity;
导入android.content.Intent;
导入android.database.Cursor;
导入android.database.sqlite.SQLiteDatabase;
导入android.os.Bundle;
导入android.view.view;
导入android.view.view.OnClickListener;
导入android.widget.AdapterView;
导入android.widget.AdapterView.OnItemSelectedListener;
导入android.widget.ArrayAdapter;
导入android.widget.Button;
导入android.widget.Spinner;
导入android.widget.Toast;
公共类mySpinnerClass扩展活动实现
OnItemSelectedListener{
私人维塔巴尼;
专用数据库数据库;
纺纱机;
按钮btnAdd;
字符串数据库名;
int选择值;
创建时的公共void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.spinner);
数据库名称=”;
selectedValue=-1;
Intent i=getIntent();
dataBaseName=i.getStringExtra(“dataBaseName”);
veritabani=新veritabani(本);
db=veritabani.getWritableDatabase();
//旋转元件
微调器=(微调器)findViewById(R.id.mySpinner);
//添加按钮
btnAdd=(按钮)findViewById(R.id.addButton);
//微调器单击侦听器
spinner.setOnItemSelectedListener(此);
//从数据库加载微调器数据
加载SpinnerData();
btnAdd.setOnClickListener(新视图.OnClickListener(){
公共void onClick(视图arg0){
如果(数据库名==“phoneOrientation”){
Intent=getIntent();
intent.putExtra(“phoneOrientation”,selectedValue);
设置结果(结果正常,意图);
完成();
}
else if(dataBaseName==“phonePosition”){
Intent=getIntent();
intent.putExtra(“phonePosition”,selectedValue);
设置结果(结果正常,意图);
完成();
}
else if(dataBaseName==“Label”){
Intent=getIntent();
intent.putExtra(“标签”,selectedValue);
设置结果(结果正常,意图);
完成();
}
}
});
}
私有void loadSpinnerData(){
//微调器下拉元素
列表标签=getAllLabels();
//为微调器创建适配器
ArrayAdapter dataAdapter=新的ArrayAdapter(此,
android.R.layout.simple_微调器(项目、标签);
//下拉式布局样式-带单选按钮的列表视图
数据适配器
.setDropDownViewResource(android.R.layout.simple\u微调器\u下拉菜单\u项);
//将数据适配器连接到微调器
spinner.setAdapter(dataAdapter);
}
公共列表getAllLabels(){
列表标签=新的ArrayList();
//选择所有查询
String selectQuery=“SELECT*FROM”+数据库名称;
Cursor Cursor=db.rawQuery(selectQuery,null);
//循环遍历所有行并添加到列表
if(cursor.moveToFirst()){
做{
labels.add(cursor.getString(cursor.getColumnIndex(“isim”));
}while(cursor.moveToNext());
}
//闭合连接
//退回标签
退货标签;
}
public int returnID(字符串项){
int toBereturnedID;
Cursor myCursor=db.rawQuery(“从“+dataBaseName+”中选择_id,其中isim=“+””“+item+””,null);
myCursor.moveToFirst();
toBereturnedID=myCursor.getInt(0);
返回到RETURNEDID;
}
已选择公共位置(AdapterView父视图、视图arg1、整型位置、长arg3){
//TODO自动生成的方法存根
String label=parent.getItemAtPosition(position.toString();
selectedValue=returnID(标签);
}
未选择公共无效(AdapterView arg0){
//TODO自动生成的方法存根
}
}

尝试创建新的意图,而不是getIntent()


希望有帮助。

您正在调用
loadSpinnerData()onCreate()
中的code>方法,因此
dataBaseName
始终为空,因此您希望在单击时具有微调器的值,您需要使用on
onClick()
按钮方法调用该值,该方法将为您提供正确的
dataBaseName
并使用
dataBaseName.equals(“phoneOrientation”)
而不是
dataBaseName==“phoneOrientation”

应使用equals属性比较字符串:
if(dataBaseName.equals(“phoneOrientation”)){
试着修改一下哦,我错过了。非常感谢。onClickListener正在工作吗?是的,它现在工作得很好:)是的,但我应该得到绑定到当前活动的意图。所以我必须得到意图。问题是由字符串比较引起的。谢谢。dataBaseName是从主活动传递的。每当我创建活动中,它通过intent传递并设置为局部变量(dataBaseName),其大小为onCreate()方法的头部大小。在某些情况下,我可能需要在此活动中列出不同的数据库元素。因此,对于if语句,将检查传递的“dataBaseName”。比较是
Intent intent=new Intent();
intent.putExtra("label",selectedValue);
setResult(RESULT_OK, intent);
finish();