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

Android 自带的资源

字符串资源:

  • 定义字符串资源在 ;
  • 在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



    

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);
    }
}


        
        

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);
    }
}


        
        
        

总结 添加Action View

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

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

实现层次式导航

  • 布局界面创建FriendsActivity
  • 判断父Activity 是否为空, 不为空设置返回导航显示
  • 为FriendActity 配置父Activity (需要在Mainifiest.xml 添加说明父Activity)


    
    
    
        
            
                
                
            
        
       
           >

           
       
    
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
            }
        });
    }
}




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);
        }
    }
}


到此这篇关于Android资源文件与层次式导航超详细讲解的文章就介绍到这了,更多相关Android资源文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(Android资源文件与层次式导航超详细讲解)