Android——基本控件(下)(十九)

这篇具有很好参考价值的文章主要介绍了Android——基本控件(下)(十九)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1. 菜单:Menu

1.1 知识点

(1)掌握Android中菜单的使用;

(2)掌握选项菜单(OptionsMenu)的使用;

(3)掌握上下文菜单(ContextMenu)的使用;

(4)掌握子菜单(SubMenu)的使用;

1.2 具体内容

Android——基本控件(下)(十九),Android,开发语言,android

Android——基本控件(下)(十九),Android,开发语言,android 

Android——基本控件(下)(十九),Android,开发语言,android 

package com.example.menuproject;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;

public class MenuActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_menu);
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		menu.add(Menu.NONE,//菜单不分组
				Menu.FIRST+1,//菜单项的id
				1,//菜单的编号
				"添加")//菜单标题
		        .setIcon(//设置菜单图标
		        R.drawable.add);
		menu.add(Menu.NONE,Menu.FIRST+2,2,"保存").setIcon(R.drawable.save);
		menu.add(Menu.NONE,Menu.FIRST+3,3,"编辑").setIcon(R.drawable.edit);
		menu.add(Menu.NONE,Menu.FIRST+4,4,"详细").setIcon(R.drawable.detail);
		menu.add(Menu.NONE,Menu.FIRST+5,5,"删除").setIcon(R.drawable.delete);
		menu.add(Menu.NONE,Menu.FIRST+6,6,"更多").setIcon(R.drawable.more);
		return true;
	}

}

 只需要在onCreateOptionsMenu(Menu menu)去进行菜单的设置就行

@Override
	public boolean onPrepareOptionsMenu(Menu menu){
		Toast.makeText(this, "菜单显示前操作", 0).show();
		return true;
	}

以上是在菜单显示之前执行的一个方法,可以从父类当中去覆写以便实现一些逻辑

@Override
	public void onOptionsMenuClosed(Menu menu){
		Toast.makeText(this, "选项关闭", 0).show();
	}

以上实在菜单关闭之后执行的一个方法。

@Override
	public boolean onOptionsItemSelected(MenuItem item){
		switch (item.getItemId()){
		case Menu.FIRST+1:
			Toast.makeText(this, "这是添加菜单项", 0).show();
		    break;
		case Menu.FIRST+2:
			Toast.makeText(this, "这是保存菜单项", 0).show();
		    break;
		case Menu.FIRST+3:
			Toast.makeText(this, "这是编辑菜单项", 0).show();
		    break;
		case Menu.FIRST+4:
			Toast.makeText(this, "这是详情菜单项", 0).show();
		    break;
		case Menu.FIRST+5:
			Toast.makeText(this, "这是删除菜单项", 0).show();
		    break;
		case Menu.FIRST+6:
			Toast.makeText(this, "这是更多菜单项", 0).show();
		    break;
		}
		return false;
	}

以上都是在Activity当中去添加菜单选项。

当然也可以在xml文件中添加菜单选项。

<menu xmlns:android="http://schemas.android.com/apk/res/android" >

    <item
        android:id="@+id/m1"
        android:orderInCategory="100"
        android:title="添加"/>
    <item
        android:id="@+id/m2"
        android:orderInCategory="101"
        android:title="保存"/>
    <item
        android:id="@+id/m3"
        android:orderInCategory="102"
        android:title="编辑"/>
    <item
        android:id="@+id/m4"
        android:orderInCategory="103"
        android:title="详情"/>
    <item
        android:id="@+id/m5"
        android:orderInCategory="104"
        android:title="删除"/>
    <item
        android:id="@+id/m6"
        android:orderInCategory="105"
        android:title="更多"/>
    

</menu>

此处需要注意的是,加载的xml文件不是layout文件而是menu文件

@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		super.getMenuInflater().inflate(R.menu.menu, menu);
		return true;
	}
	

上下文菜单

Android——基本控件(下)(十九),Android,开发语言,android

package com.example.menuproject;

import android.app.Activity;
import android.os.Bundle;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.Menu;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.ListView;

public class MenuActivity extends Activity {
    String data[] ={"中国高校培训","培训课程","万策智业"};
    ListView listView;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		this.listView = new ListView(this);
		listView.setAdapter(new ArrayAdapter<String>(this,android.R.layout.simple_expandable_list_item_1,this.data));
		super.registerForContextMenu(listView);//注册上下文菜单
		super.setContentView(listView);
	}

	@Override
	public void onCreateContextMenu(ContextMenu menu,View v,ContextMenuInfo menuInfo) {
		super.onCreateContextMenu(menu, v, menuInfo);
		menu.setHeaderTitle("信息操作");
		menu.add(Menu.NONE,Menu.FIRST+1,1,"添加联系人");
		menu.add(Menu.NONE,Menu.FIRST+2,2,"查看详情");
		menu.add(Menu.NONE,Menu.FIRST+3,3,"删除信息");
		menu.add(Menu.NONE,Menu.FIRST+4,4,"编辑");
	}
	
	
}

 以上是实现上下文菜单组件

@Override
	public boolean onContextItemSelected(MenuItem item){
		switch (item.getItemId()){
		case Menu.FIRST+1:
			Toast.makeText(this, "添加联系人", 0).show();
		    break;
		case Menu.FIRST+2:
			Toast.makeText(this, "查看详情", 0).show();
		    break;
		case Menu.FIRST+3:
			Toast.makeText(this, "删除信息", 0).show();
		    break;
		case Menu.FIRST+4:
			Toast.makeText(this, "编辑", 0).show();
		    break;
	
		}
		return false;
	}

子菜单:SubMenu

Android——基本控件(下)(十九),Android,开发语言,android

@Override
	public boolean onCreateOptionsMenu(Menu menu){
		SubMenu fileMenu = menu.addSubMenu("文件");
		SubMenu editMenu = menu.addSubMenu("编辑");
		
		fileMenu.add(Menu.NONE,Menu.FIRST+1,1,"新建");
		fileMenu.add(Menu.NONE,Menu.FIRST+2,2,"打开");
		editMenu.add(Menu.NONE,Menu.FIRST+3,3,"保存");
		editMenu.add(Menu.NONE,Menu.FIRST+4,4,"撤销");
		return true;
	}

 子菜单的监听

@Override
	public boolean onOptionsItemSelected(MenuItem item){
		switch (item.getItemId()){
		case Menu.FIRST+1:
			Toast.makeText(this, "新建子菜单", 0).show();
		    break;
		case Menu.FIRST+2:
			Toast.makeText(this, "打开子菜单", 0).show();
		    break;
		case Menu.FIRST+3:
			Toast.makeText(this, "保存子菜单", 0).show();
		    break;
		case Menu.FIRST+4:
			Toast.makeText(this, "撤销子菜单", 0).show();
		    break;
	    }
		return false;
	}

1.3 小结

(1)界面开发之中使用菜单可以有效的对工具集进行管理;

(2)Android中一共分为三种菜单:选项菜单(OptionsMenu)、上下文菜单(ContextMenu)和子菜单(SubMenu)。

2. 隐式抽屉组件:SlidingDrawer

2.1 知识点

(1)掌握SlidingDrawer 的主要作用及实现;

(2)掌握SlidingDrawer 组件的事件处理方式;

2.2 具体内容

Android——基本控件(下)(十九),Android,开发语言,android

Android——基本控件(下)(十九),Android,开发语言,android 

 

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".SlidingDrawerActivity" >

    <SlidingDrawer 
        android:id="@+id/sd"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="horizontal"
        android:handle="@+id/img"
        android:content="@+id/content"
        >
        <ImageView 
            android:id="@+id/img"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/pic_8"
            />
        <LinearLayout
            android:id="@+id/content"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical"
            >
        </LinearLayout> 
    </SlidingDrawer>
    
    
    
</LinearLayout>

定义一个内嵌LInearLayout,以便能够在后台动态添加程序集

package com.example.slidingdrawer;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.SlidingDrawer;
import android.widget.SlidingDrawer.OnDrawerCloseListener;
import android.widget.SlidingDrawer.OnDrawerOpenListener;
import android.widget.SlidingDrawer.OnDrawerScrollListener;
import android.widget.Toast;

public class SlidingDrawerActivity extends Activity {
    String data[]={"兰州","定西","武威","张掖"};
    ListView listView = null;
    SlidingDrawer sd = null;
    ImageView img = null;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_sliding_drawer);
		LinearLayout content = (LinearLayout) super.findViewById(R.id.content);
		listView = new ListView(this);
		listView.setAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_expandable_list_item_1,data));
		content.addView(this.listView);
		sd = (SlidingDrawer) super.findViewById(R.id.sd);
		img = (ImageView) super.findViewById(R.id.img);
		sd.setOnDrawerOpenListener(new OnDrawerOpenListenerImpl());
		sd.setOnDrawerCloseListener(new OnDrawerCloseListenerImpl());
		sd.setOnDrawerScrollListener(new OnDrawerScrollListenerImpl());
		
	}

	private class OnDrawerOpenListenerImpl implements OnDrawerOpenListener{

		@Override
		public void onDrawerOpened() {
			img.setImageResource(R.drawable.pic_6);
		}
		
	}
	private class OnDrawerCloseListenerImpl implements OnDrawerCloseListener{

		@Override
		public void onDrawerClosed() {
			img.setImageResource(R.drawable.pic_8);
			
		}
		
	}
    private class OnDrawerScrollListenerImpl implements OnDrawerScrollListener{

		@Override
		public void onScrollEnded() {
          Toast.makeText(SlidingDrawerActivity.this, "窗口拖动结束", 0).show();
		}

		@Override
		public void onScrollStarted() {
			// TODO Auto-generated method stub
			Toast.makeText(SlidingDrawerActivity.this, "窗口拖动开始", 0).show();
		}}
}

2.3 小结

(1)使用SlidingDrawer 组件可以更好的管理按钮操作集。

3. 缩放控制:ZoomControls

3.1 知识点

(1)掌握ZoomControls组件的使用;

3.2 具体内容

Android——基本控件(下)(十九),Android,开发语言,android

实现利用缩放组件进行对字体大小缩放。

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".ZoomControlsActivity" >

    <TextView
        android:id="@+id/tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="ZoomControls控件控制文字缩放" 
        android:textSize="10dp"
        />
    
    <ZoomControls 
        android:id="@+id/zoomcontrols"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:gravity="bottom"
        />

</LinearLayout>

 

package com.example.zoomcontrols;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.TextView;
import android.widget.ZoomControls;

public class ZoomControlsActivity extends Activity {
    int size =10;
    TextView tv = null;
    ZoomControls zc =null;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_zoom_controls);
		zc = (ZoomControls) super.findViewById(R.id.zoomcontrols);
		tv = (TextView) super.findViewById(R.id.tv);
		zc.setOnZoomInClickListener(new OnZoomInCLickListenerImpl());
		zc.setOnZoomOutClickListener(new OnZoomOutCLickListenerImpl());
	}
    //放大监听
    private class OnZoomInCLickListenerImpl implements OnClickListener{

		@Override
		public void onClick(View v) {
			ZoomControlsActivity.this.size += 2;
			ZoomControlsActivity.this.tv.setTextSize(size);
		}
    	
    	
    }
    //缩小监听
    private class OnZoomOutCLickListenerImpl implements OnClickListener{

		@Override
		public void onClick(View v) {
			ZoomControlsActivity.this.size -= 2;
			ZoomControlsActivity.this.tv.setTextSize(size);
		}
    	
    	
    }
}

3.3 小结

(1)ZoomControls组件可以由用户根据自己的需要控制显示的大小。

4. 弹出窗口:PopupWindow

4.1 知识点

(1)掌握弹出窗口的基本实现;

(2)掌握弹出窗口的事件处理操作;

4.2 具体内容

Android——基本控件(下)(十九),Android,开发语言,android

弹出窗口意味着在原有的手机上,增加一个专门的显示层,作为弹出窗口显示的空间。

Android——基本控件(下)(十九),Android,开发语言,android 

既然PopupWindow组件是可以直接在界面上显示自己的一个界面层,那么就需要专门的一个布局管理器文件,来定PopupWindow组件。

<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="请选择您所需要的状态" />
    <RadioGroup 
        android:id="@+id/checkStatus"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        >
        <RadioButton 
            android:id="@+id/onLine"
            android:layout_width="match_parent"
        	android:layout_height="wrap_content"
            android:text="在线"
            />
        <RadioButton 
            android:id="@+id/offLine"
            android:layout_width="match_parent"
        	android:layout_height="wrap_content"
            android:text="离线"
            />
        <RadioButton 
            android:id="@+id/steach"
            android:layout_width="match_parent"
        	android:layout_height="wrap_content"
            android:text="隐身"
            />
    </RadioGroup>
	<Button 
	    android:id="@+id/cancel"
	    android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="取消"
	    />
</LinearLayout>

以上的布局管理器就是一个作为PopupWindow的显示。

现在我们来定义我们主布局管理器。

<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    <TextView
        android:id="@+id/statusInfo"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="用户当前状态:在线" />
    <Button 
        android:id="@+id/popbut"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="选择状态"
        />

</LinearLayout>

以上就是主布局管理器,现在还有一个问题,现在是通过按钮事件去弹出PopupWindow,那么肯定需要一个转换器将需要显示的布局管理器设置到PopupWindow上。这时需要使用LayoutInflater进行转换。现在我们来编写Activity程序。

package com.example.popupwindowproject;

import android.app.Activity;
import android.os.Bundle;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.PopupWindow;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import android.widget.RadioGroup.OnCheckedChangeListener;
import android.widget.TextView;
public class PopupWindowActivity extends Activity {
	private  Button statuBut = null;
	private TextView statuInfo = null;
	private RadioGroup checkStatu = null;
	private Button cancelBut = null;
	private PopupWindow popWin = null;
	private View popView = null;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		super.setContentView(R.layout.activity_popup_window);
		this.statuBut = (Button) super.findViewById(R.id.popbut);
		this.statuInfo = (TextView) super.findViewById(R.id.statusInfo);
		this.statuBut.setOnClickListener(new OnClickListener(){
			@Override
			public void onClick(View v) {
				LayoutInflater inflater = LayoutInflater.from(PopupWindowActivity.this);
				PopupWindowActivity.this.popView = (View) inflater.inflate(R.layout.popup_window, null);//将布局文件转换成组件
				PopupWindowActivity.this.popWin = new PopupWindow(PopupWindowActivity.this.popView,300,220);//创建一个新的PopupWindow
				PopupWindowActivity.this.popWin.setContentView(PopupWindowActivity.this.popView);//设置显示组件
				PopupWindowActivity.this.checkStatu = (RadioGroup) PopupWindowActivity.this.popView.findViewById(R.id.checkStatus);
				PopupWindowActivity.this.cancelBut = (Button) PopupWindowActivity.this.popView.findViewById(R.id.cancel);
				PopupWindowActivity.this.checkStatu.setOnCheckedChangeListener(new OnCheckedChangeListener() {
					@Override
					public void onCheckedChanged(RadioGroup group, int checkedId) {
						RadioButton rbut = (RadioButton) PopupWindowActivity.this.popView.findViewById(group.getCheckedRadioButtonId());//取得选中的组件ID
						PopupWindowActivity.this.statuInfo.setText("您选中的状态是:"+rbut.getText());//修改我们文本显示组件的内容
					}
				});
				PopupWindowActivity.this.cancelBut.setOnClickListener(new OnClickListener() {
					@Override
					public void onClick(View v) {
						// TODO Auto-generated method stub
						PopupWindowActivity.this.popWin.dismiss();//隐藏PopupWindow
					}
				});
				PopupWindowActivity.this.popWin.showAtLocation(PopupWindowActivity.this.statuBut,Gravity.CENTER, 0, 0);//显示弹出窗口
			}
		});
	}
}

是要是组件就离不开布局文件,有个前提:就是组件中显示的内容会比较多。

4.3 小结

(1)弹出窗口需要一个单独的布局管理器进行配置;

(2)可以使用LayoutInflater通过配置文件读取组件信息;文章来源地址https://www.toymoban.com/news/detail-683618.html

到了这里,关于Android——基本控件(下)(十九)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Android开发基础——自定义控件

    Android中常用控件和布局的继承结构如下图所示:  从上面可以看出,所有控件都是直接或间接继承自View的,所用的所有布局都是直接或间接继承自ViewGroup的。View是Android中最基本的一种UI组件,其可以在屏幕上绘制一块矩形区域,并能够响应这块区域的各种事件,因此,用户

    2023年04月10日
    浏览(36)
  • Android开发控件形状之自定义圆角button(三种形态)

    第一步:在drawable文件下创建button的形状描述文件btn_shape.xml btn1.xml btn2.xml btn3.xml 第二步:在布局文件中layout.xml中对btn1.xml以上三种其中一种的引用语句,用来设置button形状: android:background=\\\"@drawable/btn1\\\" 效果图: 点击前 点击后     解析shape文件中的android:shape属性:  Android

    2024年02月13日
    浏览(42)
  • Android应用开发-Flutter的LongPressDraggable控件回调函数onDraggableCanceled使用

    以下是如何使用 onDraggableCanceled 的示例: velocity 参数表示拖动被取消时的速度信息。 offset 参数表示拖动被取消时的偏移量信息。 这个回调通常用于在拖动被取消时执行一些清理工作或展示一些反馈。例如,你可能想要将拖动对象返回到原始位置,或者显示一个提示,告诉用

    2024年03月08日
    浏览(42)
  • Android开发——控件EditText, 2.获取EditText输入的数据,通过按钮点击实现,ImageView控件,缩放类型,控件ProgressBar,常用属性详解,进度条设置

    1. android : hint 输入提示 2. android : textColorHint  输入提示文字的颜色 3. android : inputType  输入类型 4. android : drawableXxxx 在输入框的指定方位添加图片 5. android : drawablePadding  设置图片与输入内容的间距 6. android : paddingxxxx  设置内容与边框的间距 7. android : backgrou

    2024年02月07日
    浏览(48)
  • Android-NDK开发——基本概念

    在Android开发中,有时候出于安全,性能,代码共用的考虑,需要使用C/C++编写的库。虽然在现代化工具链的支持下,这个工作的难度已经大大降低,但是毕竟万事开头难,初学者往往还是会遇到很多不可预测的问题。本篇就是基于此背景下写的一份简陋指南,希望能对刚开始编

    2024年02月09日
    浏览(38)
  • Android应用开发(4)视图布局基本属性

    Android应用开发学习笔记——目录索引 本章介绍视图(View)的基本概念及其用法,包括:如何设置视图的宽度和高度,如何设置视图的外部间距和内部间距,如何设置视图的外部对齐方式和内部对齐方式等。 在Android中,什么是视图(View)?View是Android中所有控件的基类,不

    2024年02月03日
    浏览(44)
  • Android开发之Compose基础学习-Surface容器的基本使用

    先上图 再看代码

    2024年02月15日
    浏览(43)
  • 第五十九章 Unity 发布Android平台

    本章节我们讲解如何打包发布到安卓手机平台。要为 Android 构建和运行应用程序,必须安装 Unity Android Build Support 平台模块。还需要安装 Android 软件开发工具包(SDK)和原生开发工具包(NDK)才能在 Android 设备上构建和运行代码。默认情况下,Unity 会安装基于 OpenJDK 的 Java 开

    2024年02月14日
    浏览(43)
  • 【常用开发工具】保姆级教程Android Studio安装和基本使用

    🔎这里是【常用开发工具】,关注我学习编程不迷路 如果对你有帮助,给博主一个免费的点赞👍以示鼓励 欢迎各位🔎点赞👍评论收藏⭐️ 👀专栏介绍 【常用开发工具】 目前更新IDEA、Tomcat、Maven、Git等预计会开10+期,大家一起学习一起进步。 📢📢有写的不好或写错的地

    2023年04月16日
    浏览(57)
  • 【Android从零单排系列四十九】《Android中自定义Fragment的实现方法》

    目录 前言 一  Fragment介绍 二  Fragment的缺点 三  自定义Fragment的步骤 四 自定义Fragment的demo 小伙伴们,在前面的文章中,我们谈到了Android开发中的自定义view的基本概念及方法等,本文我们实际举例自定义一个Fragment。 Fragment是Android中一种用于构建灵活和可重用界面组件的基

    2024年02月13日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包