Android View标签LabelView(电商、商城类APP常用)



Android View标签LabelView(电商、商城类APP常用)

LabelView是在github上一个开源的标签库。其项目主页是:https://github.com/linger1216//labelview
LabelView为一个TextView,ImageView或者为ListView中适配器getView返回的View,增加一个左上角或者右上角的标签,要实现的效果如图所示:


这种需求设计在商城类APP、电商类APP中比较常用,这些APP展示的商品,通常会增加一些促销或者该类商品的特征。
LabelView集成自Android TextView,可以像使用Android TextView一样使用LabelView,LabelView使用简单,如代码所示:

package zhangphil.demo;

import com.lid.lib.LabelView;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;

public class MainActivity extends Activity {

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

		// 为一个普通的Android TextView增加标签
		LabelView label1 = new LabelView(this);
		label1.setText("HOT");
		label1.setBackgroundColor(0xffff5722);
		label1.setTargetView(findViewById(R.id.textView1), 5, LabelView.Gravity.LEFT_TOP);

		// 为一个普通的Android TextView增加标签
		// 点击则删除LabelView
		final LabelView label2 = new LabelView(this);
		label2.setText("HOT");
		label2.setBackgroundColor(0xffff5722);
		label2.setTargetView(findViewById(R.id.textView2), 5, LabelView.Gravity.RIGHT_TOP);
		label2.setOnClickListener(new View.OnClickListener() {

			@Override
			public void onClick(View v) {
				// 删除标签
				label2.remove();
			}
		});

		// 为一个Android ImageView增加标签
		LabelView label3 = new LabelView(this);
		label3.setText("HOT");
		label3.setBackgroundColor(0xffff5722);
		label3.setTargetView(findViewById(R.id.imageView), 5, LabelView.Gravity.RIGHT_TOP);

		// 为一个Android View增加标签
		LabelView label4 = new LabelView(this);
		label4.setText("HOT");
		label4.setBackgroundColor(0xffff5722);
		label4.setTargetView(findViewById(R.id.view), 5, LabelView.Gravity.RIGHT_TOP);
	}
}


布局文件则很简单,就使用Android自身的基础View:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="zhangphil.demo.MainActivity" >

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="100dip"
        android:background="#e0e0e0"
        android:gravity="center"
        android:text="Zhang Phil" >
    </TextView>

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="100dip"
        android:layout_marginTop="5dip"
        android:background="#e0e0e0"
        android:gravity="center"
        android:text="Zhang Phil" >
    </TextView>

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="100dip"
        android:layout_height="100dip"
        android:layout_marginTop="5dip"
        android:background="#e0e0e0"
        android:src="@drawable/ic_launcher" >
    </ImageView>

    <View
        android:id="@+id/view"
        android:layout_width="100dip"
        android:layout_height="100dip"
        android:layout_marginTop="5dip"
        android:background="#e0e0e0" >
    </View>

</LinearLayout>

代码运行结果就是上文中所示效果。



LabelView的distance和设置的text代表涵义如图所示:

转载于:https://my.oschina.net/zhangphil/blog/1601714

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在移动应用程序中,块级标签的左右滑动可以通过以下步骤实现: 1.使用一个横向滚动视图容器来包含块级标签。例如,使用一个`UIScrollView`或者`UICollectionView`来作为容器。 2.在容器中添加块级标签作为子视图。可以使用`UILabel`或者自定义的视图来作为块级标签。 3.设置容器的`contentSize`属性为所有子视图的宽度之和,使其可以横向滚动。 4.如果需要分页滚动,则可以设置容器的`pagingEnabled`属性为`YES`,使其每次只滚动一个子视图的宽度。 例如,以下代码可以实现一个左右滑动的标签列表: Swift代码: ```swift import UIKit class ViewController: UIViewController { @IBOutlet weak var scrollView: UIScrollView! override func viewDidLoad() { super.viewDidLoad() let labels = ["标签1", "标签2", "标签3", "标签4", "标签5", "标签6", "标签7", "标签8", "标签9", "标签10"] var xOffset: CGFloat = 0 for label in labels { let labelView = UILabel() labelView.text = label labelView.textAlignment = .center labelView.backgroundColor = .gray labelView.textColor = .white labelView.frame = CGRect(x: xOffset, y: 0, width: 100, height: 50) scrollView.addSubview(labelView) xOffset += 110 } scrollView.contentSize = CGSize(width: xOffset, height: scrollView.frame.height) } } ``` 在这个例子中,我们创建了一个`UIScrollView`作为容器,并添加了10个`UILabel`作为子视图。我们设置每个`UILabel`的宽度为100,间距为10,使其可以左右滑动。最后,我们设置了容器的`contentSize`属性为所有子视图的宽度之和,使其可以横向滚动。 这样,标签列表就可以在移动应用程序中左右滑动了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值