android - 在android中创建自定义日历形状,如谷歌日历图像
问题描述
我想创建自定义日历形状,如谷歌日历图标,并将其用作其他视图(如 ImageView 和 Textview)的容器我尝试使用 XML 可绘制形状,结果似乎不好,我尝试以编程方式创建它,但我不知道如何将其他视图放在自定义视图中创建它的正确方法是什么?
bg_calendar_view.xml
<!-- Gray shadow. -->
<item>
<shape>
<solid android:color="#dadada" />
<corners android:radius="15dp" />
</shape>
</item>
<!-- White foreground. -->
<item
android:top="3dp"
android:left="2dp"
android:bottom="1dp"
>
<shape>
<solid android:color="@android:color/white" />
<corners android:radius="15dp" />
</shape>
</item>
bg_notification_view.xml
<!-- Gray shadow. -->
<item>
<shape>
<solid android:color="#dadada" />
<corners android:radius="15dp" />
</shape>
</item>
<!-- White foreground. -->
<item
android:bottom="3dp"
android:top="1dp"
android:left="2dp">
<shape>
<solid android:color="@android:color/white" />
<corners android:radius="15dp" />
</shape>
</item>
bg_bottom_calendar.xml
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:bottom="4dp"
android:right="25dp"
android:left="25dp"
android:drawable="@drawable/bg_notification_view">
</item>
<item
android:left="15dp"
android:bottom="20dp"
android:right="15dp"
android:drawable="@drawable/bg_notification_view">
</item>
<item
android:bottom="40dp"
android:drawable="@drawable/bg_notification_view">
</item>
bg_top_calendar.xml
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:bottom="4dp"
android:right="25dp"
android:left="25dp"
android:drawable="@drawable/bg_calendar_view">
</item>
<item
android:right="15dp"
android:left="15dp"
android:top="20dp"
android:drawable="@drawable/bg_calendar_view">
</item>
<item
android:top="40dp"
android:drawable="@drawable/bg_calendar_view_blue">
</item>
my_layout.xml
<LinearLayout android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="vertical"
xmlns:android="http://schemas.android.com/apk/res/android"
android:gravity="center"
android:padding="16dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="250dp"
android:background="@drawable/bg_top_calendar"
android:padding="40dp"
android:gravity="center"
android:orientation="vertical"
>
<ImageView
android:layout_width="100dp"
android:layout_height="100dp"
android:src="@drawable/notification"
android:layout_gravity="center"
android:layout_marginBottom="8dp"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="you Have 31 Notification"
android:textColor="@color/white"
android:textSize="18sp"/>
</LinearLayout>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="250dp"
android:background="@drawable/bg_bottom_calendar"
android:paddingBottom="40dp"
android:paddingStart="4dp"
android:paddingEnd="4dp"
android:paddingTop="4dp"
>
</FrameLayout>
解决方案
我们开发了几个月的日历。
首先,我们使用线性布局来填充单元格。我们有 35 个单元格,每个单元格包含 1 个 RelativeLayout 和 3 个 TextView。
然后我们以编程方式将视图填充到单元格中,这很容易,但结果却是一个非常缓慢的实现。然后我们使用 RecyclerView 来实现单元格,但它并没有大幅加速。
一旦我们发现我们的瓶颈是填充复杂视图 35 次。
然后我们看到了一个关于自定义视图的视频。因此,经过大量研究,我们决定尝试自定义视图,瞧!它像魅力一样解决了我们的滞后问题。
你也应该像我们一样尝试一下。
推荐阅读
- python - Django:取消订单时无法调整库存
- jboss - 如何在 Jhipster 生成的项目中为 Keycloak 启用 https?
- ios - 如何检测 UICollectionViewCell 的中点何时超出 UICollectionView 的框架?
- python - lambda函数或自定义函数
- android - Android Studio:在try finally块中调用recycle时如何使用obtainStyledAttributes解决lint警告
- r - CRAN 包提交
- javascript - 如何在 React 中显示自动完成文本字段中的选定值?
- vb.net - 刷新图表区
- javascript - 防止大多数用户从网站下载视频文件的最佳做法
- c# - 这个抽象类是否有另一种方法可以从这个泛型类型派生?错误 CS0310