Android
代码填空
-
设置控件的可见性和不可见性
- 设置控件可见
myButton.setVisiblility(View.VISIBLE)
- 设置控件不可见但保留空间
myButton.setVisiblility(View.INVISIBLE)
- 设置控件为不可见且不保留空间
myButton.setVisiblility(View.GONE)
-
sharepreferens存储和读取
//存储数据 SharedPreferences sharedPreferences = getSharedPreferences("MyPreferences",Context.MODE_PRIVATE); SharedPreferences.Editor editor = sharedPreferences.edit(); edit.putString("key_string","hello world!"); editor.apply(); //读数据 String valueString = sharedPreferences.getString("key_string","No value found"); Toast.makeText(this,"Value: " + valueString,Toast.LENGTH_SHORT).show()
-
关闭当前页面
- 在Activity内部关闭自身:简单调用finish()方法
public void closeActivity(){ finish() } //你可以在按钮的点击事件监听器、菜单项的选择监听器等地方调用这个方法
- 另一个Activity中关闭前一个Activity: 使用startActivityForResult()和setResult() , 并在前一个Activity的onActivityResult()方法中调用finish().更常见的做法是让结果页面自己调用finish()
- 在Fragment中关闭它的Activity: 如果你在一个Fragment中,并且想要包含该Fragment的Activity,你可以通过调用**getActivity.finish()**来实现
public void closeContainingActivity(){ if(getActivity != null){ getActivity().finish(); } } //注意:在调用 finish()之前检查 getActivity()是否返回 null 是很重要的,因为 Fragment 可能在 Activity 已经销毁之后仍然保留在内存中。
- 对话窗弹出窗口中关闭背后的Activity: 通常需要在对话框某个回调中调用finish() . 但是,这通常意味着对话框是由该 Activity 管理的, 所以你应该在该 Activity 的某个方法中调用 finish()
4.接受页面传递对象的序列化
5.页面延时跳转
6.应用样式到布局文件中
7.video view 控件的使用
简答题
-
如何实现数据回传
-
启动Activity并等待结果:在原始Activity中,使用Intent启动另一个Activity,并调用startActivityForResult(intent,requestCode).
其中,requestCode是一个用于在结果返回时区分不同请求的整数值
-
在目标Activity中设置结果:在目标 Activity 中,当用户完成操作后,创建一个新的 Intent, 将需要回传的数据放入其中.
调用 setResult(resultCode, intent)。其中,resultCode 通常 使用 RESULT_OK 或 RESULT_CANCELED来表示成功或取消.
调用 finish()来关闭目标 Activity 并返回结果
-
在原始Activity中接收结果:在原始Activity中,重写**onActivityResult(int requestCode,int resultCode,Intent data)**方法
在这个方法中,你可以通过 requestCode 来区分不同的请求,通 过 resultCode 来判断操作是否成功,通过 data 来获取回传的数据。
虽然这些方法主要用于持久化存储数据,但你也可以将它们 用于在 Activity 之间传递数据。然而,这种方法通常不是最佳实践,因为它可能会导致不必要 的 I/O 操作和性能问
-
-
创建对话框步骤
- 确定对话框类型
根据需求确定对话框的类型,如提示对话框、选择对话框(单选、 多选)、列表对话框等。
- 设置对话框属性
标题:为对话框设置标题,用于简要说明对话框的用途。
图标:如果需要,可以为对话框设置图标,以增强视觉效果。
内容:为对话框设置要显示的内容,这可以是简单的文本消息,也可以是复杂的布局。
按钮:根据需要添加按钮,如“确定”、“取消”等,并为这些按 钮设置点击事件监听器。
构 建 对 话 框: 使 用 Android 提 供 的 对 话 框 构 建 工 具 ( 如 AlertDialog.Builder)来构建对话框。
- 显示对话框
调用对话框的 show()方法来显示对话框。
处理对话框关闭事件(可选):如果需要在对话框关闭时执行某些操作(如清理资源),可以设置 一个对话框关闭事件监听器。
代码题
-
SQLite创建增删改查四个方法:
public class MyDatabaseHelper extends SQLiteOpenHelper {
private static final String DB_NAME = "MyDatabase.db";
private static final int DB_VERSION = 1;
private static final String TABLE_NAME = "MyTable";
private static final String COLUMN_ID = "_id";
private static final String COLUMN_NAME = "name";
public MyDatabaseHelper(Context context) {
super(context, DB_NAME, null, DB_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
String createTableQuery = "CREATE TABLE " + TABLE_NAME + " (" + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT,
" + COLUMN_NAME + " TEXT " + ")"; db.execSQL(createTableQuery);
}
// ... 其他方法,如 onUpgrade()等
}
2.插入(增)
java public void insertData(String name){
SQLiteDatabase db = myDatabaseHelper.getWritableDatabase();
ContentValues values=new ContentValues();
values.put(MyDatabaseHelper.COLUMN_NAME,name);
db.insert(MyDatabaseHelper.TABLE_NAME,null,values);
db.close();
}
3.删除(删)
java public void deleteData(int id){
SQLiteDatabase db=
myDatabaseHelper.getWritableDatabase();
db.delete(MyDatabaseHelper.TABLE_NAME,
MyDatabaseHelper.COLUMN_ID+" = ?",
new String[]{String.valueOf(id)});
db.close();
}
4.查询(查)
java public Cursor getData(){
SQLiteDatabase db=myDatabaseHelper.getReadableDatabase();
return db.query(MyDatabaseHelper.TABLE_NAME,null,null,
null,null,null,null);
}
// 然后在某个地方使用 Cursor 遍历结果
Cursor cursor=getData();
if(cursor.moveToFirst()){
do{
int id=
cursor.getInt(cursor.getColumnIndex(MyDatabaseHelper.COLUMN_ID));
String name=
cursor.getString(cursor.getColumnIndex(MyDatabaseHelper.COLUMN_NAME));
// 处理数据...
}while(cursor.moveToNext());
}
cursor.close();
5.更新(改)
java public void updateData(int id,String new newName){
SQLiteDatabase db=myDatabaseHelper.getWritableDatabase();
ContentValues values=new ContentValues();
values.put(MyDatabaseHelper.COLUMN_NAME,newName);
db.update(MyDatabaseHelper.TABLE_NAME,values,
MyDatabaseHelper.COLUMN_ID+" = ?",
new String[]{String.valueOf(id)});
db.close();
}
-
Recycle View适配器
// 定义数据源 ArrayList<String> dataList=new ArrayList<>(); // ... 填充数据到 dataList 中 // 初始化 ListView ListView listView=findViewById(R.id.list_view); // 使用 ArrayAdapter ArrayAdapter<String> adapter=new ArrayAdapter<>(this,android.R.layout.simple_list_item_1,dataList); // 将适配器设置到 ListView listView.setAdapter(adapter); // 如果需要更新数据,只需更新 dataList 并调用 notifyDataSetChanged()(但ArrayAdapter 没有直接提供这个方法) // 一个简单的解决办法是重新创建适配器并设置到 ListView dataList.add("新增的条目"); adapter=new ArrayAdapter<>(this,android.R.layout.simple_list_item_1,dataList); listView.setAdapter(adapter); // Recycle View 适配器 public class MyRecyclerViewAdapter extends RecyclerView.Adapter<MyRecyclerViewAdapter.ViewHolder> { private ArrayList<String> dataList; public MyRecyclerViewAdapter(ArrayList<String> dataList) { this.dataList = dataList; } @NonNull @Override public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { // 创建 ViewHolder 并绑定视图 View itemView = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_list, parent, false); return new ViewHolder(itemView); } @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { // 绑定数据到 ViewHolder 的视图上 holder.textView.setText(dataList.get(position)); } @Override public int getItemCount() { // 返回数据项的数量 return dataList.size(); } public class ViewHolder extends RecyclerView.ViewHolder { TextView textView; public ViewHolder(@NonNull View itemView) { super(itemView); textView = itemView.findViewById(R.id.text_view); // // 假设 item_list.xml 中有一个 TextView,其 ID 为 text_view } } // 如 果 需 要 更 新 数 据 , 只 需 更 新 dataList 并 调 用 notifyDataSetChanged() public void updateData(ArrayList<String> newData) { this.dataList = newData; notifyDataSetChanged(); } }