您好,登錄后才能下訂單哦!
這篇文章主要介紹Android如何實現帶角標的ImageView,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
角標繪制過程:用畫筆量出一個字符的寬度作為角標背景的半徑(R),然后判斷傳入字符串的總長度
如果只有一位字符:那么就以 R 為半徑,畫一個圓,然后在圓中寫上數字
如果有兩位以上的字符,就不能單純用一個圓了,用畫筆測量字符串的完整長度( len ),然后在右上角畫一個圓,在這個圓的圓心左邊 len 長度的位置 作為圓心再畫一個圓,最后以這個兩個圓的上下頂點(一共四個)構成一個矩形,進行填充
效果如下:
集成方法
在Project的 build.gradle 下添加
allprojects { repositories { ... maven { url 'https://jitpack.io' } } }
在Module的 build.gradle 下添加
dependencies { compile 'com.github.SiKang123:AndroidToolBox:1.0' }
使用方法
圖片中的效果,Layout:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center_horizontal" android:orientation="vertical" android:paddingTop="50dp"> <android.simple.toolbox.widget.CornerImageView android:layout_width="50dp" android:layout_height="50dp" android:layout_margin="20dp" android:src="@mipmap/ic_launcher" app:cornerBackground="@color/red" app:cornerText="9" app:cornerTextColor="@color/white" app:cornerTextSize="11dp" /> <android.simple.toolbox.widget.CornerImageView android:layout_width="50dp" android:layout_height="50dp" android:layout_margin="20dp" android:src="@mipmap/ic_launcher" app:cornerBackground="@color/red" app:cornerText="99" app:cornerTextColor="@color/white" app:cornerTextSize="11dp" /> <android.simple.toolbox.widget.CornerImageView android:layout_width="50dp" android:layout_height="50dp" android:layout_margin="20dp" android:src="@mipmap/ic_launcher" app:cornerBackground="@color/red" app:cornerText="999" app:cornerTextColor="@color/white" app:cornerTextSize="11dp" /> <android.simple.toolbox.widget.CornerImageView android:id="@+id/progress_imageview" android:layout_width="60dp" android:layout_height="60dp" android:layout_margin="20dp" android:src="@mipmap/ic_launcher" app:cornerBackground="@mipmap/shanchu" app:cornerLoadColor="@color/alpha_black_35" app:cornerRadius="7dp" /> </LinearLayout>
Activtiy:
@Override protected void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_cornerimage); //設置最后一個圖片的加載進度為20%,并添加點擊事件 CornerImageView imageView = (CornerImageView) findViewById(R.id.progress_imageview); imageView.progress(20); imageView.setOnCornerClickListener(new CornerImageView.OnCornerClickListener() { @Override public void onCornerClickListener(View view) { Toast.makeText(SimpleCornerImageActivity.this, "角標被點擊", Toast.LENGTH_SHORT).show(); } }); }
Android是一種基于Linux內核的自由及開放源代碼的操作系統,主要使用于移動設備,如智能手機和平板電腦,由美國Google公司和開放手機聯盟領導及開發。
以上是“Android如何實現帶角標的ImageView”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。