我的Android进阶之旅------Android利用温度传感器实现带动画效果的电子温度计
???? 要想實現帶動畫效果的電子溫度計,需要以下幾個知識點:
1、溫度傳感器相關知識。
2、ScaleAnimation動畫相關知識,來進行水印刻度的縮放效果。
3、android:layout_weight屬性的合理運用,關于android:layout_weight屬性的講解,可以參考:《我的Android進階之旅------>關于android:layout_weight屬性的一個面試題》
地址為:http://blog.csdn.net/ouyang_peng/article/details/13236519
???? 首先來看看本實例的具體效果,然后再來具體實現功能。
1、將溫度強制設置為0度時,畫面如下:
?
?
2、將溫度強制設置為50度時,畫面如下:
?
?
3、將溫度強制設置為-20度時,畫面如下:
?
?
4、從傳感器動態得到溫度值,并實時更新畫面,如下所示:
?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
本文《我的Android進階之旅------>Android利用溫度傳感器實現有動畫效果的電子溫度計》
(地址:http://blog.csdn.net/ouyang_peng/article/details/48790289)
?
?
首先來看布局文件的代碼:layout_thermometer.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/Parent"android:layout_width="fill_parent"android:layout_height="fill_parent"android:background="@drawable/background_thermometer"android:clipChildren="false"android:clipToPadding="false"android:gravity="bottom|center"android:keepScreenOn="true"android:orientation="vertical" ><FrameLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_gravity="bottom|center" ><LinearLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:orientation="vertical" ><!-- 頂部圖片 --><ImageViewandroid:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_gravity="center"android:src="@drawable/background_top" /><LinearLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_weight="100.0"android:orientation="horizontal" ><!-- 橫向空白占1份 --><LinearLayoutandroid:layout_width="0dp"android:layout_height="fill_parent"android:layout_weight="1"android:gravity="bottom|center" ></LinearLayout><!-- 橫向占4份 --><LinearLayoutandroid:id="@+id/meter"android:layout_width="0dp"android:layout_height="wrap_content"android:layout_marginTop="10dp"android:layout_weight="4"android:animationCache="true"android:background="@drawable/thermometer_dial"android:clipChildren="false"android:clipToPadding="false"android:persistentDrawingCache="all" ><!-- 橫向占189份,刻度表左邊刻度攝氏溫度所占比例 --><LinearLayoutandroid:layout_width="0dp"android:layout_height="fill_parent"android:layout_weight="189"android:visibility="invisible" /><!-- 橫向占69份,刻度表水銀柱子所在區域所占比例 --><LinearLayoutandroid:layout_width="0dp"android:layout_height="fill_parent"android:layout_weight="69"android:orientation="vertical" ><!-- 豎向占131.0份,刻度表50°以上的部分 --><LinearLayoutandroid:layout_width="fill_parent"android:layout_height="0dp"android:layout_weight="131.0" /><!--豎向占773.0份,水銀針正好等于刻度表從-20°到50° 因為柱子和圓球直接有點斷層,把773變成774默認不顯示柱子,當有傳感器數據時,才顯示出來 --><LinearLayoutandroid:id="@+id/alcohol"android:layout_width="fill_parent"android:layout_height="0dp"android:layout_weight="774.0"android:background="@drawable/alcohol"android:orientation="horizontal"android:visibility="invisible" /><!--豎向占104.0份 ,刻度表-20°以上的部分 因為柱子和圓球直接有點斷層,把104變成103--><LinearLayoutandroid:layout_width="fill_parent"android:layout_height="0dp"android:layout_weight="103.0" /></LinearLayout><!-- 橫向占189份,刻度表右邊刻度華氏溫度所占比例 --><LinearLayoutandroid:layout_width="0dp"android:layout_height="fill_parent"android:layout_weight="187"android:visibility="invisible" /></LinearLayout><!-- 橫向占4份 --><LinearLayoutandroid:layout_width="0dp"android:layout_height="wrap_content"android:layout_marginTop="150dp"android:layout_weight="4"android:gravity="center"android:orientation="vertical"android:paddingLeft="30dp" ><LinearLayoutandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:gravity="center"android:orientation="horizontal" ><!-- 攝氏溫度 --><TextViewandroid:id="@+id/thermo_c"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textColor="#e9bc57"android:textSize="38sp" /><!-- 攝氏溫度圖標 --><ImageViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center"android:paddingLeft="2dp"android:src="@drawable/thermo_c" /></LinearLayout><!-- 分割線 --><ImageViewandroid:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_gravity="center"android:src="@drawable/divider" /><LinearLayoutandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:gravity="center"android:orientation="horizontal" ><!-- 華氏溫度 --><TextViewandroid:id="@+id/thermo_f"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textColor="#dadada"android:textSize="18sp" /><!-- 華氏溫度圖標 --><ImageViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center"android:paddingLeft="2dp"android:src="@drawable/thermo_f" /></LinearLayout></LinearLayout><!-- 橫向空白占1份 --><LinearLayoutandroid:layout_width="0dp"android:layout_height="fill_parent"android:layout_weight="1"android:gravity="bottom|center" ></LinearLayout></LinearLayout><LinearLayoutandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center"android:gravity="center_vertical"android:orientation="vertical" ><!-- 作者信息--><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:textColor="#ffff00"android:textSize="18sp"android:text="@string/author"android:layout_gravity="center"/><!-- 博客地址 --><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:autoLink="web"android:text="@string/blog_address"android:textColor="#ffff00"android:textSize="18sp" /></LinearLayout><!-- 尾部圖片 --><ImageViewandroid:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_gravity="center"android:src="@drawable/background_bottom" /></LinearLayout></FrameLayout></LinearLayout>
接著看Activity的代碼:ThermometerActivity.java
?
?具體代碼可以在下面地址中免費下載:
?
?http://download.csdn.net/detail/qq446282412/9145961
? 作者:歐陽鵬? 歡迎轉載,與人分享是進步的源泉!
? 轉載請保留原文地址:http://blog.csdn.net/ouyang_peng
====================================================================================
?
轉載于:https://www.cnblogs.com/ouyangpeng/p/8537889.html
總結
以上是生活随笔為你收集整理的我的Android进阶之旅------Android利用温度传感器实现带动画效果的电子温度计的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MySQL的timestamp字段可以使
- 下一篇: Android 获得ImageView中