Wear Os基础入门

WearableRecyclerView


在这里插入图片描述

布局

<?xml version="1.0" encoding="utf-8"?>
<androidx.wear.widget.WearableRecyclerView
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/recycler_launcher_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:scrollbars="vertical" />

资源

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:padding="4dp"
    android:paddingEnd="?android:listPreferredItemPaddingEnd">
    <ImageView
        android:id="@+id/icon_image_view"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/a"/>
    <TextView
        android:id="@+id/icon_text_view"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_marginStart="8dp"
        android:gravity="center_vertical"
        android:text="张三" />
</LinearLayout>

代码

package com.chery.wearosdemo;

/**
 * @author DcotorWei
 * @date :2020/3/19 9:58
 * @description :TODO
 * @email :1348172474@qq.com
 */

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;

import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;

import java.util.List;

public class MyAdapter<T> extends RecyclerView.Adapter<MyAdapter.MyViewHolder> {
    private Context context;
    private List<T> data;

    public MyAdapter(Context context, List<T> data) {
        this.context = context;
        this.data = data;
    }

    @NonNull
    @Override
    public MyAdapter.MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(context).inflate(R.layout.app_item_layout, parent, false);
        MyViewHolder viewHolder=new MyViewHolder(view);
        return viewHolder;
    }

    @Override
    public void onBindViewHolder(@NonNull MyAdapter.MyViewHolder holder, int position) {
        holder.mTextView.setText((CharSequence) data.get(position));
    }

    @Override
    public int getItemCount() {
        return data.size();
    }
    static class MyViewHolder extends RecyclerView.ViewHolder{
        TextView mTextView;
        ImageView mImageView;
        public MyViewHolder(@NonNull View itemView) {
            super(itemView);
            mTextView = itemView.findViewById(R.id.icon_text_view);
            mImageView = itemView.findViewById(R.id.icon_image_view);
        }

    }

}

package com.chery.wearosdemo;

import android.os.Bundle;
import android.support.wearable.activity.WearableActivity;
import android.view.View;

import androidx.recyclerview.widget.RecyclerView;
import androidx.wear.widget.WearableLinearLayoutManager;
import androidx.wear.widget.WearableRecyclerView;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends WearableActivity {


    private WearableRecyclerView wearableRecyclerView;

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


        // Enables Always-on
        setAmbientEnabled();
    }


    private void initView() {
        wearableRecyclerView = (WearableRecyclerView) findViewById(R.id.recycler_launcher_view);

        List<String> datas = new ArrayList<>();
        for (int i = 0; i < 7; i++) {
            datas.add("" + i);
        }

        CustomScrollingLayoutCallback customScrollingLayoutCallback =
                new CustomScrollingLayoutCallback();


        wearableRecyclerView.setLayoutManager(
                new WearableLinearLayoutManager(this,customScrollingLayoutCallback));
        // To align the edge children (first and last) with the center of the screen
        wearableRecyclerView.setEdgeItemsCenteringEnabled(true);
        wearableRecyclerView.setAdapter(new MyAdapter(this, datas));
    }
    public class CustomScrollingLayoutCallback extends WearableLinearLayoutManager.LayoutCallback {
        /** How much should we scale the icon at most. */
        private static final float MAX_ICON_PROGRESS = 0.65f;


        @Override
        public void onLayoutFinished(View child, RecyclerView parent) {

            // Figure out % progress from top to bottom.
            float centerOffset = (child.getHeight() / 2.0f) / parent.getHeight();
            float yRelativeToCenterOffset = (child.getY() / parent.getHeight()) + centerOffset;

            // Normalize for center.
            float progressToCenter = Math.abs(0.5f - yRelativeToCenterOffset);

            // Adjust to the maximum scale.
            progressToCenter = Math.min(progressToCenter, MAX_ICON_PROGRESS);

            child.setScaleX(1 - progressToCenter);
            child.setScaleY(1 - progressToCenter);
        }
    }

}


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Wear OS是由Google开发的智能手表操作系统。它提供了许多功能和应用程序,让用户能够更方便地使用他们的智能手表。 首先,要使用Wear OS,您需要将其安装在您的智能手表上。许多智能手表默认都预装了此操作系统,但如果没有,您可以从Google Play商店中下载并安装它。 安装完成后,您需要将手表与您的手机进行配对。打开手表上的蓝牙设置,并在您的手机上搜索新设备。找到您的手表后,将其与手机进行配对。一旦配对成功,您的手表就可以与手机同步,并开始接收通知、查看日历、控制音乐等功能。 接下来,您可以开始个性化设置您的手表。通过访问手表的设置菜单,您可以更改手表的表盘、背景、字体大小等。您还可以调整手表的通知设置,选择您想要在手表上显示的通知类型。 Wear OS还支持许多应用程序,包括Google Fit健身追踪、Google Maps导航、Google Pay支付等。您可以在手表上打开Google Play商店,浏览并安装您感兴趣的应用程序。 最后,Wear OS还有一些手势和快捷方式,可以帮助您更方便地操作手表。例如,您可以通过在手表面板上向左滑动来访问快速设置,如亮度调整、飞行模式等。通过向上滑动,您可以查看手表的通知历史记录。 总体而言,Wear OS是一个功能强大的智能手表操作系统,提供了许多定制选项和方便功能。通过理解操作系统的不同功能和设置,您可以最大限度地发挥手表的潜力,并让它更好地满足您的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值