Android4.0新控件

谷歌在推出Android4.0的同时推出了一些新控件,Android4.0中最常用的新控件有下面5种。 

1. Switch的使用



Switch顾名思义,就是开关的意思,有开和关两种状态。

当Switch处于关闭状态时: 
 
当Switch处于打开状态时: 

怎么在定义xml中定义Switch


    <Switch
    android:id="@+id/_switch"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textOff="关闭"
    android:textOn="打开" />
  • android:textOff属性表示Switch关闭时显示的文本
  • android:textOn属性表示Switch打开时显示的文本

    mSwitch= (Switch) findViewById(R.id._switch);
    mSwitch.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
        @Override
        public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
            if(isChecked){
                Log.i("Switch","打开Switch");
            }else{
                Log.i("Switch","关闭Switch");
            }
        }
    });

2. Space的使用



Space顾名思义是空间的意思,表示该控件占据一定的空间,但是却不显示任何东西。

怎么使用Space


    <android.support.v4.widget.Space
    android:layout_width="match_parent"
    android:layout_height="60dp" />

3. GridLayout的使用



GridLayout是指网格布局,GridLayout是为了弥补TableLayout的一些不足而推出来的。 
- TableLayout不能同时在水平和垂直两个方向上对齐,因为TableLayout继承LinearLayout。 
- TableLayout中的元素不能跨行或者跨列,因为TableLayout不能明确指出占多少行和多少列。

GridLayout中元素常用的属性

  • android:layout_row : 固定显示在第几行。
  • android:layout_column : 固定显示在第几列
  • android:layout_rowSpan : 跨几行
  • android:layout_columnSpan: 跨几列

怎么使用GridLayout

 <GridLayout
    android:id="@+id/grid_layout"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:columnCount="2"
    android:rowCount="2">

    <Button android:text="打开PopupMenu"
        android:onClick="openPopupMenu"/>

    <Button android:text="TextureView不旋转"
        android:onClick="rotate0"/>
    <Button android:text="TextureView旋转45度"
        android:onClick="rotate45"/>
    <Button android:text="TextureView旋转90度"
        android:onClick="rotate90"/>
</GridLayout>

4. PopupMenu的使用



PopupMenu顾名思义是弹出菜单,它可以在一个控件的下面显示弹出菜单。

在xml中定义弹出菜单

在menu资源目录下面新建一个菜单的xml文件

<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<item android:title="Switch" />
<item android:title="Space" />
<item android:title="GridLayout" />
<item android:title="PopupMenu" />
<item android:title="TextureView" />
</menu>

怎么显示PopupMenu

public void openPopupMenu(View view){
    //popupMenu显示在view下面
    PopupMenu popupMenu=new PopupMenu(this,view);
    //从xml文件中加载菜单到popupMenu中
    popupMenu.inflate(R.menu.popup_menu);
    //显示  popupMenu
    popupMenu.show();
}

5. TextureView的使用



TextureView是SurfaceView的补充,它不像SurfaceView一样创建特殊的窗口,它创建一个常规的View,TextureView可以设置移动,旋转,动画等。 
一个Textureview可以用来显示内容流。这样的内容流可以是视频或OpenGL场景。内容流可以来自于应用程序的进程以及远程进程。Textureview只能用于硬件加速的窗口。当渲染软件,Textureview什么都不会画。

怎么使用TextureView

使用Textureview很简单:你需要做的就是得到它的SurfaceTexture。然后,SurfaceTexture可用于呈现内容。 
下面的示例演示如何渲染相机预览到Textureview: 
因为使用了相机,所以要在添加AndroidManifest.xml 文件中添加对应的权限 
<uses-permission android:name="android.permission.CAMERA"/>

public class MainActivity extends AppCompatActivity implements TextureView.SurfaceTextureListener{private TextureView mTexture;
    private Camera mCamera;
    @Overrideprotected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTexture= (TextureView) findViewById(R.id.texture_view);
        //为mTexture设置表面结构监听器
        mTexture.setSurfaceTextureListener(this);

    }

    /**
     * TextureView的SurfaceTexture准备开始用
     */@Overridepublic void onSurfaceTextureAvailable(SurfaceTexture surface, int width, int height) {
        mCamera = Camera.open();
        try {
            //设置mCamera的表面结构为surface
            mCamera.setPreviewTexture(surface);
            //启动相机预览
            mCamera.startPreview();
            //设置mTexture透明度
            mTexture.setAlpha(1.0f);
            //设置mTexture旋转角度
            mTexture.setRotation(90.0f);
        } catch (IOException ioe) {
            // Something bad happened
        }

    }

    /**
     * SurfaceTexture的缓存大小改变了
     */@Overridepublic void onSurfaceTextureSizeChanged(SurfaceTexture surface, int width, int height) {

    }

    /**
     * SurfaceTexture销毁了
     */@Overridepublic boolean onSurfaceTextureDestroyed(SurfaceTexture surface) {
        mCamera.stopPreview();
        mCamera.release();
        return true;
    }

    /**
     * SurfaceTexture更新了
     */@Overridepublic void onSurfaceTextureUpdated(SurfaceTexture surface) {

    }
}

xml文件中TextureView是这样定义的

    <TextureView
        android:id="@+id/texture_view"android:layout_width="match_parent"android:layout_height="match_parent">
        </TextureView>

注意:TextureView设置旋转90度才是我们的正常视角。

原文地址:https://www.cnblogs.com/ganchuanpu/p/8394825.html

时间: 2024-11-06 16:13:07

Android4.0新控件的相关文章

一个Activity掌握Android4.0新控件 (转)

原文地址:http://blog.csdn.net/lavor_zl/article/details/51261380 谷歌在推出Android4.0的同时推出了一些新控件,Android4.0中最常用的新控件有下面5种. 1. Switch的使用 Switch顾名思义,就是开关的意思,有开和关两种状态. 当Switch处于关闭状态时: 当Switch处于打开状态时: 怎么在定义xml中定义Switch <Switch android:id="@+id/_switch" andr

一个Activity掌握Android5.0新控件 (转)

原文地址:http://blog.csdn.net/lavor_zl/article/details/51279386 谷歌在推出Android5.0的同时推出了一些新控件,Android5.0中最常用的新控件有下面5种. 1. CardView(卡片视图) CardView顾名思义是卡片视图,它继承FrameLayout.它是一个带圆角的背景和阴影FrameLayout.CardView被包装为一种布局,并且经常在ListView和RecyclerView的Item布局中,作为容器使用. Ca

Android5.0新控件CardView的介绍和使用

   CardView也是5.0的新控件,这控件其实就是一个卡片啦,当然我们自己也完全可以定义这样一个卡片,从现在的微博等社App中可以看到各式各样的自定义卡片,所以这个控件意义不是很大.比较是support中的view所以使用在布局里面的时候一下子看不到效果的,比较不好.CardView继承的是FrameLayout,所以摆放内部控件的时候需要注意一下啦. 建议:个人不是很建议用这个控件,因为我们完全可以自定义这样一个控件,这样既能在布局时直接看到效果又比较方便,关键问题是CardView中的

Android5.0新控件

谷歌在推出Android5.0的同时推出了一些新控件,Android5.0中最常用的新控件有下面5种.  1. CardView(卡片视图) CardView顾名思义是卡片视图,它继承FrameLayout.它是一个带圆角的背景和阴影FrameLayout.CardView被包装为一种布局,并且经常在ListView和RecyclerView的Item布局中,作为容器使用. CardView的使用非常简单: 1 <android.support.v7.widget.CardView 2 andr

Windows 8.1 新控件和功能:

将 XAML 树呈现为位图: 适用于 Windows 8.1 的 Windows 运行时为 Windows.UI.Xaml.Media.Imaging 命名空间添加了一种新类型:RenderTargetBitmap. 此类型提供了两个关键方法: RenderTargetBitmap.RenderAsync,用于提取 XAML 可视化树 并为其创建位图表示. 注意  此操作采用异步方式,将给定的 XAML 元素树呈现为位图. 此方法与屏幕刷新不同步,不能保证精确的帧计时,因此该位图可能在假定捕获时

Android M新控件之AppBarLayout,NavigationView,CoordinatorLayout,CollapsingToolbarLayout的使用

[转载请注明出处:http://blog.csdn.net/feiduclear_up/article/details/46514791 CSDN 废墟的树] 上一篇博客我们学习了Android Design Support Library库中的 是个简单的组件,不了解的童鞋可以参考之前的博客 Android M新控件之FloatingActionButton,TextInputLayout,Snackbar,TabLayout的使用. 这篇博客我们继续学习Design库中的其他四个组件,分别是

MFC9.0 Outlook控件的标题显示无法修改

这是我在开发中遇到的问题,现记录下来,以便帮助你们. 不想看废话的可以只看最后三行,但你会错过很多. 俗话说的好啊,"Wise men learn by other men's mistakes; fools by their own." -------------------------------------------分割线首次登场--------------------------------------------- 可能有的童鞋英语不太好,看不懂上面的东东,好吧我活跃下气氛

Android Design新控件之TextInputLayout(文本输入布局)

谷歌在推出Android5.0的同时推出了全新的设计Material Design,谷歌为了给我们提供更加规范的MD设计风格的控件,在2015年IO大会上推出了Design支持包,Design常用的新控件包括: TextInputLayout(文本输入布局) TabLaout(选项卡布局) Snackbar FloatingActionButton(浮动按钮) NavigationView(导航视图) AppBarLayout(程序栏布局) CoordinatorLayout(协作布局) Col

一个Activity掌握Design新控件

一个Activity掌握Design新控件 欢迎转载,转载请注明原文地址:http://blog.csdn.net/lavor_zl/article/details/51295364谢谢. 谷歌在推出Android5.0的同时推出了全新的设计Material Design,谷歌为了给我们提供更加规范的MD设计风格的控件,在2015年IO大会上推出了Design支持包,Design常用的新控件有下面8种. 1. TextInputLayout(文本输入布局) TextInputLayout的作用是