第一次安卓作业笔记:一个星座查询app

任务要求:

写一个星座查询,进去后先是一个欢迎界面,再之后选择完日期,显示星座图标。

效果预览:在这里插入图片描述在这里插入图片描述

一、布局欢迎界面

在这里插入图片描述
xml文件activity_main为欢迎界面,在B站天哥布局的视频教程基础上。我选用了线性布局LinearLayout。

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.MainActivity">

    <LinearLayout
        android:layout_width="match_parent" 使用所有可用空间
        android:layout_height="match_parent">
        <Button
            android:id="@+id/welcomeButton"
            android:layout_width="match_parent"
            android:background="@drawable/radius"   设置了一个圆角按钮,在背景这儿导入了网上搜到的圆角美化的图标控件。

            android:layout_height="200dp"
            android:layout_gravity="center"  gravity:设置偏向某个方向,center就是居中
            android:text="点击开始"
            android:textColor="#ff68"
            android:textSize="60dp"/>   

    </LinearLayout>

</android.support.constraint.ConstraintLayout>

这是网上找的圆角图标的xml,在 drawable下新建一个xml文件复制进去的。

<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >

    <!-- 填充的颜色 -->
    <solid android:color="#ccf" />

    <!-- 边框的颜色 :不能和窗口背景色一样-->
    <stroke
        android:width="3dp"
        android:color="#ffffff" />

    <!-- 设置按钮的四个角为弧形 -->
    <!-- android:radius 弧形的半径 -->
    <corners android:radius="30dp" />

    <!-- padding:Button里面的文字与Button边界的间隔 -->
    <padding
        android:bottom="10dp"
        android:left="10dp"
        android:right="10dp"
        android:top="10dp" />
</shape>

第二个activity,在layout下直接新建一个activity

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/data">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">  定义控件垂直分布

        <TextView	放了一个文本框
            android:layout_width="100dp"	 
            android:layout_height="40dp" 	
            android:layout_marginLeft="140dp" 	左边距
            android:layout_marginTop="40dp" 	顶部边距
            android:background="#FF00cc"	 背景
            android:gravity="center" 	文字居中

            android:text="选择出生日期"	 文本内容
            android:textSize="15dp"	 文字大小
            />

        <DatePicker 	DatePicker控件
            android:id="@+id/dataPicker" 	定义ID
            android:layout_width="match_parent" 	
            android:layout_height="220dp"
            android:layout_marginTop="20dp"
            android:calendarViewShown="false" 	挂历显示关掉	
            android:datePickerMode="spinner"	 设置他为滚动式的日历显示方式,挂历的不好看还得自己调整
            />
        <Button
            android:id="@+id/rsbt"
            android:layout_width="90dp"
            android:layout_height="60dp"
            android:text="查询"
            android:layout_gravity="center"
            android:background="@drawable/radius"/> 	背景也是导入的
        <TextView	这个是显示查询的星座名称的
            android:id="@+id/txrs"
            android:layout_width="wrap_content" 这种宽度是匹配文字的
            android:layout_height="wrap_content"
            android:layout_marginTop="15dp"
            android:layout_gravity="center"
            android:gravity="center"
            android:background="#FFcc88"
            />
        <ImageView 	这个是显示星座图标的
            android:id="@+id/ivrs"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            />

    </LinearLayout>


</LinearLayout>

开始编辑JAVA部分

欢迎界面

package com.example;

import android.annotation.SuppressLint;
import android.content.Intent;
import android.graphics.Color;
import android.net.sip.SipSession;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.widget.Button;
import android.app.Activity;

public class MainActivity extends AppCompatActivity {
    private Button bt; //注册欢迎按钮

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main); // 跟这个activity绑定对应的xml界面
        bt = (Button) findViewById(R.id.welcomeButton);  //绑定欢迎按钮
        bt.setOnClickListener(new View.OnClickListener() { //设置一个点击事件
            @Override
            public void onClick(View view) {
                Intent intent = new Intent(); //注册一个组件间的通信器,这里是用来跳转页面的
                intent.setClass(MainActivity.this,Data.class); //设置通信连接的内容
                startActivity(intent); //启动
            }
        });
    };
}

这是第二个界面的Java内容

package com.example;

import android.content.Intent;
import android.os.Bundle;
import android.os.Looper;
import android.os.PersistableBundle;
import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.DatePicker;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;

import java.util.Calendar;

/**
 * Created by 须臾 on 2020/5/28.
 */

public class Data extends AppCompatActivity implements DatePicker.OnDateChangedListener{
    Button bt;//注册按钮、图片显示器、文本显示器
    TextView tv;
    ImageView iv;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_data);
        final DatePicker datePicker = (DatePicker)findViewById(R.id.dataPicker);//绑定datepicker
//后边想给日历先一个初始化,从1970年开始不好看
        Calendar calendar = Calendar.getInstance();  //注册一个日历,这个对应的是现实时间
        int year=calendar.get(Calendar.YEAR); //获取现实时间的年月日
        int monthOfYear=calendar.get(Calendar.MONTH);
        int dayOfMonth=calendar.get(Calendar.DAY_OF_MONTH);
        datePicker.init(year,monthOfYear,dayOfMonth,this);//给datepicker初始化年月日
        bt = (Button)findViewById(R.id.rsbt);//绑定
        iv = (ImageView) findViewById(R.id.ivrs);
        tv =(TextView) findViewById(R.id.txrs) ;
        bt.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {   //给按钮设置触发事件
                int year=datePicker.getYear(); //这个是要查询日期的三个变量
                int month=datePicker.getMonth();
                int day=datePicker.getDayOfMonth();
                String res ;
                float data = month+1+((float)day)/100; //这个想把日期转换为一个浮点型数字,日/100+月,从而进行判断
                if (data>=3.21&&data<=4.20){
                    res = "白羊座";
                    iv.setImageResource(R.drawable.byz); //设置图片显示器显示的资源

                }
                else if (data>=4.21&&data<=5.21){
                    res = "金牛座";
                    iv.setImageResource(R.drawable.jnz);

                }
                else if (data>=5.22&&data<=6.21){
                    res = "双子座";
                    iv.setImageResource(R.drawable.shzz);

                }
                else if (data>=6.22&&data<=7.22){
                    res = "巨蟹座";
                    iv.setImageResource(R.drawable.jxz);

                }
                else if (data>=7.23&&data<=8.23){
                    res = "狮子座";
                    iv.setImageResource(R.drawable.szz);

                }
                else if (data>=8.24&&data<=9.23){
                    res = "处女座";
                    iv.setImageResource(R.drawable.cnz);
                }
                else if (data>=9.24&&data<=10.23){
                    res = "天秤座";
                    iv.setImageResource(R.drawable.tcz);
                }
                else if (data>=10.24&&data<=11.22){
                    res = "天蝎座";
                    iv.setImageResource(R.drawable.txz);
                }
                else if (data>=11.23&&data<=12.21){
                    res = "射手座";
                    iv.setImageResource(R.drawable.ssz);
                }
                else if ((data>=1.01&&data<=1.20)){
                    res = "魔蝎座";
                    iv.setImageResource(R.drawable.mjz);
                }
                else if (data>=2.20&&data<=3.20){
                    res = "双鱼座";
                    iv.setImageResource(R.drawable.syz);
                }
                else { //水瓶座因为在12.22后1.20前,干脆写到else里
                    res = "水瓶座";
                    iv.setImageResource(R.drawable.spz);
                }
/* 白羊座: 3月21日~4月20日 (Aries)金牛座: 4月21日~5月21日 (Taurus)双子座: 5月22日~6月21日 (Gemini)巨蟹座: 6月22日~7月22日 (Cancer)
狮子座: 7月23日~8月23日 (Leo)处女座: 8月24日~9月23日 (Virgo)天秤座: 9月24日~10月23日 (Libra)天蝎座: 10月24日~11月22日 (Scorpio)
射手座: 11月23日~12月21日 (Sagittarius)摩羯座: 12月22日~1月20日 (Capricorn)水瓶座: 1月21日~2月19日 (Aquarius)双鱼座: 2月20日~3月20日 (Pisces)*/
                tv.setText(res); //设置文本显示器的内容
            }
        });


    }
//intent的信息接收
    @Override
    public void startActivityForResult(Intent intent, int requestCode) {
        super.startActivityForResult(intent, requestCode);
    }
//弹出一个提示选择的日期,但因为没设置线程,就还存在点儿bug
    @Override
    public void onDateChanged(DatePicker datePicker, int year, int month, int day) {
        Toast.makeText(Data.this,"您选择的日期是:"+year+"年"+(month+1)+"月"+day+"日!",Toast
                .LENGTH_SHORT).show();
    }
}

最后是有一个manifests我注意到的问题

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example">

    <application
        android:allowBackup="true"

        android:icon="@drawable/tubiao" 这是我改动了一下APP图标,导入的png,没有去再整圆角的图标了
        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=".Data"/>
            <!--<intent-filter>-->
                <!--<action android:name="android.intent.action.MAIN" />-->
这些被注释的代码是app启动入口,如果写俩,那安装完,桌面就会有俩app图标,所以只在启动的activity里
写就行了,实际上这个是如果创建activity自动会生成,我第一次写是直接创建的空xml文件,所以又废了很大
周折。
                <!--<category android:name="android.intent.category.LAUNCHER" />-->
            <!--</intent-filter>-->
        <!--</activity>-->
    </application>

</manifest>

中间其实还看了很多有帮助没帮助的文档,学习了控件、xml的一些知识.还有各种不知道为什么代码没错但程序出现了的错误,甚至采用了重新创建新的项目等玄学方法……

在手机上试着运行的方法:

因为Android studio 和电脑模拟器显示的不一样,跟手机也不一样,干脆用手机调试,感觉会更加可靠。
我用的华为,连上数据线,不要选择仅充电,然后去设置里找到关于本机,狂点手机版本号,直到显示开发者模式已启动。再去开发者选项里打开USB调试,其他品牌的手机可以百度USB调试打开方式。华为手机助手不连也行,关掉也行,但不能选择仅充电模式!.

还有就是修改项目名,需要重新build,可以先clean再rebuild

在这里插入图片描述

  • 16
    点赞
  • 142
    收藏
    觉得还不错? 一键收藏
  • 8
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值