Android资源文件与层次式导航超详细讲解

手机APP/开发
257
0
0
2023-07-06
标签   Android
目录
  • Action Bar
  • Action Item
  • Action View
  • 实现层次式导航

Android 自带的资源

字符串资源:

  • 定义字符串资源在 <string.xml >;
  • 在JAVA 中 使用字符串资源,通过 getResource().getString(R.string.moto) 获取strings.xml 资源,动态方式加载到textView 文本框中
TextView textview = findViewById(R.id.moto);
textview.setText(getResource().getString(R.string.moto));

2.颜色资源

# 透明度 RGB 透明度一般是4位数字

dimen 表示尺寸资源,设置格子的间距

drawable 资源:

图片资源 2. stateListDrawable资源

*.9.png : 是Android 下面自动伸缩的图片,设置png的可缩放区域,让图片中固定图像不会失真, tool下面 有个 Draw-9-patch.bat

注意图片时候不能使用大写字母

SateListDrawable :

1.失去焦点 和 汇聚焦点 使用selector

<?xml version=".0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_focused="true" android:color="#f"></item>
</selector>

Action Bar

1.提供快捷功能但是节省布局空间,比如淘宝界面上 商品分类

隐藏和显示Action bar:

1. 在AndroidMainfest.xml 对应的activity 标签上添加一个 

android:theme="@style/Theme.Appcompat.Light.NoActionBar"

之上的方式是静态方式显示控制 Action Bar

2. 动态 隐藏或者显示 Action Bar

3. ActionBar actionBar = getSupportActionBar()

button.setOnClickeListener (new ViewObClick() {
	public void onClick(View v ){
 		actionBar.hide();
 }
})

Action Item

  • 定义菜单资源文件
  • 在OnCreateOptionsMenu() 方法加载菜单资源文件

注意menu.xml 中 关键app:showAsAction这个控件 有 四个属性

always, ifRoom, never 表示Action Item 是否会显示在导航栏中,ifRoom 表示有的话可以显示,没有的话隐藏起来, 最后一个Action Item通常使用 never 角色:

package com.example.myapplication;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuInflater;
import androidx.appcompat.app.AppCompatActivity;
/**
  * Action Item显示
 */
public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // 重写这个方法 重新加载
        MenuInflater inflater = getMenuInflater();
        //解析menu 
        inflater.inflate(R.menu.menu, menu);
        return super.onCreateOptionsMenu(menu);
    }
}
<?xml version=".0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
        <!--  添加隐藏的Action item  -->
        <item android:id="@+id/search"
            android:icon="@drawable/search"
            android:title="search"
            app:showAsAction="always"
            />
</menu>

Action View

在Action Bar 上面有搜索功能的组件 叫Action View

在Action Bar上面添一些Action view 搜索的组件

package com.example.myapplication;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuInflater;
import androidx.appcompat.app.AppCompatActivity;
/**
  * 手势方式滑动动画
 */
public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // 隐藏的Action Bar 显示标题
        getSupportActionBar().setDisplayShowTitleEnabled(false);
    }
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // 重写这个方法 重新加载
        MenuInflater inflater = getMenuInflater();
        //解析menu 
        inflater.inflate(R.menu.menu, menu);
        return super.onCreateOptionsMenu(menu);
    }
}
<?xml version=".0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
        <!--  v 中自带的组件          -->
        <!-- 搜索的 Action View -->
        <item android:id= "@+id/search"
             android:title="搜索"
             app:actionViewClass="android.support.v.widget.SearchView"
             app:showAsAction="always"
            />
</menu>

总结 添加Action View

第一种: app:actionViewClass: -> 实现类(Android自带,自定义)

第二种: app:actionLayout -> 布局文件 *.xml

实现层次式导航

  • 布局界面创建FriendsActivity
  • 判断父Activity 是否为空, 不为空设置返回导航显示
  • 为FriendActity 配置父Activity (需要在Mainifiest.xml 添加说明父Activity)
<?xml version=".0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.myapplication">
    <uses-permission android:name="android.permission.CALL_PHONE"></uses-permission>
    <uses-permission android:name="android.permission.SEND_SMS"></uses-permission>
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
       <activity android:name=".FriendsActivity"
                android:label="朋友圈" <!-- 这里给添加一个Action item 是名字-- >
           >
<!--           指定当前 activity 的父activity-->
           <meta-data android:name="android.support.PARENT_ACTIVITY"
               android:value=".MainActivity"></meta-data>
       </activity>
    </application>
</manifest>
package com.example.myapplication;
import android.content.Intent;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.View;
import android.widget.ImageView;
import androidx.appcompat.app.AppCompatActivity;
/**
  * 手势方式滑动动画
 */
public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        ImageView imageView= (ImageView) findViewById(R.id.imageView); //获取朋友圈图片
        imageView.setOnClickListener(new View.OnClickListener() { //为图片设置单击事件
            @Override
            public void onClick(View v) {
                Intent intent=new Intent(MainActivity.this,FriendsActivity.class); //创建Intent对象
                startActivity(intent); //启动Activity
            }
        });
    }
}
<?xml version=".0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/relativeLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/background"
    tools:context=".MainActivity">
<!--   添加朋友圈 ImageButton的 -->
<ImageButton
    android:id="@+id/imageView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:src="@drawable/button"
    android:scaleType="fitXY"
    android:layout_marginTop="@dimen/marginTop"></ImageButton>
</RelativeLayout>
package com.example.myapplication;
import android.os.Bundle;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.NavUtils;
public class FriendsActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_friends);
        //获取父Activity 是否为空
        if(NavUtils.getParentActivityName(FriendsActivity.this) != null){
            getSupportActionBar().setDisplayHomeAsUpEnabled(true);
        }
    }
}
<?xml version=".0" encoding="utf-8"?>
<RelativeLayout
    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:background="@drawable/bg"
    tools:context=".FriendsActivity">
</RelativeLayout>