10cc064f1f
Build APK / build (pull_request) Successful in 1m42s
Rings were capped at a fixed 86dp; now each gauge fills its half of the widget (weighted ImageView) so they grow with the placed widget size. Bumped RingRenderer default bitmap to 360px/36 stroke to stay crisp at the larger display size.
170 lines
5.9 KiB
XML
170 lines
5.9 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
|
<!-- Ring style of the full (4x2) widget. Header + footer mirror widget_layout.xml (same view
|
|
IDs) so ClaudeUsageWidget can attach the same click intents and peak/refresh state; the middle
|
|
swaps the two horizontal bars for two circular RingRenderer gauges side by side. -->
|
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
|
xmlns:tools="http://schemas.android.com/tools"
|
|
android:id="@+id/widget_root"
|
|
android:layout_width="match_parent"
|
|
android:layout_height="match_parent"
|
|
android:orientation="vertical"
|
|
android:background="@drawable/widget_background"
|
|
android:padding="14dp">
|
|
|
|
<!-- Header -->
|
|
<LinearLayout
|
|
android:layout_width="match_parent"
|
|
android:layout_height="wrap_content"
|
|
android:orientation="horizontal"
|
|
android:gravity="center_vertical">
|
|
|
|
<TextView
|
|
android:layout_width="0dp"
|
|
android:layout_height="wrap_content"
|
|
android:layout_weight="1"
|
|
android:text="Claude Pro"
|
|
android:textColor="#FFFFFF"
|
|
android:textSize="13sp"
|
|
android:textStyle="bold" />
|
|
|
|
<ImageView
|
|
android:id="@+id/img_peak"
|
|
android:layout_width="16dp"
|
|
android:layout_height="16dp"
|
|
android:layout_marginEnd="4dp"
|
|
android:src="@drawable/ic_claude_burst"
|
|
android:contentDescription="Peak hours" />
|
|
|
|
<TextView
|
|
android:id="@+id/tv_peak"
|
|
android:layout_width="wrap_content"
|
|
android:layout_height="wrap_content"
|
|
android:layout_marginEnd="6dp"
|
|
android:text=""
|
|
android:textColor="#CC785C"
|
|
android:textSize="9sp"
|
|
android:textStyle="bold" />
|
|
|
|
<ImageButton
|
|
android:id="@+id/btn_refresh"
|
|
android:layout_width="32dp"
|
|
android:layout_height="32dp"
|
|
android:src="@android:drawable/ic_menu_rotate"
|
|
android:background="@android:color/transparent"
|
|
android:tint="#999999"
|
|
tools:ignore="UseAppTint"
|
|
android:contentDescription="Refresh" />
|
|
|
|
</LinearLayout>
|
|
|
|
<!-- Divider -->
|
|
<TextView
|
|
android:layout_width="match_parent"
|
|
android:layout_height="1dp"
|
|
android:layout_marginTop="8dp"
|
|
android:layout_marginBottom="6dp"
|
|
android:background="#2A2A2A" />
|
|
|
|
<!-- Two ring gauges side by side — each fills its half so the ring grows as large as the
|
|
placed widget allows (limited by the available height), instead of a fixed 86dp. -->
|
|
<LinearLayout
|
|
android:layout_width="match_parent"
|
|
android:layout_height="0dp"
|
|
android:layout_weight="1"
|
|
android:orientation="horizontal"
|
|
android:gravity="center"
|
|
android:weightSum="2">
|
|
|
|
<LinearLayout
|
|
android:layout_width="0dp"
|
|
android:layout_height="match_parent"
|
|
android:layout_weight="1"
|
|
android:orientation="vertical"
|
|
android:gravity="center_horizontal">
|
|
|
|
<ImageView
|
|
android:id="@+id/ring_session"
|
|
android:layout_width="match_parent"
|
|
android:layout_height="0dp"
|
|
android:layout_weight="1"
|
|
android:scaleType="fitCenter"
|
|
android:adjustViewBounds="false"
|
|
android:contentDescription="Session usage ring" />
|
|
|
|
<TextView
|
|
android:id="@+id/tv_session_label"
|
|
android:layout_width="match_parent"
|
|
android:layout_height="wrap_content"
|
|
android:layout_marginTop="2dp"
|
|
android:gravity="center"
|
|
android:text=""
|
|
android:textColor="#999999"
|
|
android:textSize="10sp"
|
|
android:textStyle="bold" />
|
|
|
|
</LinearLayout>
|
|
|
|
<LinearLayout
|
|
android:layout_width="0dp"
|
|
android:layout_height="match_parent"
|
|
android:layout_weight="1"
|
|
android:orientation="vertical"
|
|
android:gravity="center_horizontal">
|
|
|
|
<ImageView
|
|
android:id="@+id/ring_weekly"
|
|
android:layout_width="match_parent"
|
|
android:layout_height="0dp"
|
|
android:layout_weight="1"
|
|
android:scaleType="fitCenter"
|
|
android:adjustViewBounds="false"
|
|
android:contentDescription="Weekly usage ring" />
|
|
|
|
<TextView
|
|
android:id="@+id/tv_weekly_label"
|
|
android:layout_width="match_parent"
|
|
android:layout_height="wrap_content"
|
|
android:layout_marginTop="2dp"
|
|
android:gravity="center"
|
|
android:text=""
|
|
android:textColor="#999999"
|
|
android:textSize="10sp"
|
|
android:textStyle="bold" />
|
|
|
|
</LinearLayout>
|
|
|
|
</LinearLayout>
|
|
|
|
<!-- Footer -->
|
|
<LinearLayout
|
|
android:layout_width="match_parent"
|
|
android:layout_height="wrap_content"
|
|
android:orientation="horizontal"
|
|
android:layout_marginTop="6dp"
|
|
android:gravity="center_vertical">
|
|
|
|
<TextView
|
|
android:id="@+id/tv_status"
|
|
android:layout_width="0dp"
|
|
android:layout_height="wrap_content"
|
|
android:layout_weight="1"
|
|
android:text=""
|
|
android:textColor="#FFFFFF"
|
|
android:textSize="9sp"
|
|
android:textStyle="bold"
|
|
android:singleLine="true"
|
|
android:ellipsize="end" />
|
|
|
|
<TextView
|
|
android:id="@+id/tv_updated"
|
|
android:layout_width="wrap_content"
|
|
android:layout_height="wrap_content"
|
|
android:text=""
|
|
android:textColor="#FFFFFF"
|
|
android:textSize="9sp"
|
|
android:textStyle="bold" />
|
|
|
|
</LinearLayout>
|
|
|
|
</LinearLayout>
|