android view视图的层叠(叠加)

第一种情况:google android textview drawable
参考:           

setCompoundDrawable to add Drawables to TextView

http://mgmblog.com/2010/06/04/setcompounddrawable-to-add-drawables-to-textview/
上面是给出TextView添加Drawables时调用的方法
第二种情况:
而在图像之中想要添加文字,而又不想用一个又一个的view进行叠加怎么办呢
Bitmap bm = BitmapFactory.decodeResource(getResources(),R.drawable.a);
Bitmap bm1 = BitmapFactory.decodeResource(getResources(),R.drawable.b);
Bitmap bm2 = BitmapFactory.decodeResource(getResources(),R.drawable.c);
Drawable[] array=new Drawable[3];

array[0] = new BitmapDrawable(bm2);
array[1] = new BitmapDrawable(bm1); //白色
array[2] = new BitmapDrawable(mytext.getDrawingCache());
LayerDrawable la=new LayerDrawable(array);

la.setLayerInset(0, 0, 0, 0, 0);
la.setLayerInset(1, 200, 200, 200, 200);
la.setLayerInset(2, 400, 400, 400, 400);//第一个参数2代表数组的第三个元素,为位图资源
image.setImageDrawable(la);

上面是三个图片的叠加并显示在同一个view中,那么文字和图片如何一起叠加显示呢?

自定义视图时重载onDraw()函数提供了如下的函数
protected void onDraw(Canvas canvas) {
  super.onDraw(canvas);
  canvas.drawColor(Color.WHITE);
        /*写字*/
  paint = new Paint();
        paint.setTextSize(24);
        canvas.drawText(getResources().getString(R.string.title), 50, 50, paint);

这样直接出来的字的字体不大好看,如何解决呢?
参考: http://yarin.iteye.com/blog/518405 即可解决

来自http://jayzhou215.blog.163.com/blog/static/13271353320122104532944/
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Android Studio中,可以使用视图绑定(ViewBinding)来替代findViewById方法,以更方便地访问和操作视图元素。下面是使用视图绑定实现视图的步骤: 1. 确保你的项目已经升级到Android Studio 3.6 Canary 11或更高版本。 2. 在项目的build.gradle文件中,将以下代码添加到android块中: ```groovy viewBinding { enabled = true } ``` 3. 在布局文件中,使用<layout>标签将布局文件包裹起来,例如: ```xml <layout xmlns:android="http://schemas.android.com/apk/res/android"> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent"> <!-- 布局内容 --> </LinearLayout> </layout> ``` 4. 在Activity或Fragment中,使用以下代码来获取视图绑定实例: ```java // 对于Activity private ActivityMainBinding binding; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); binding = ActivityMainBinding.inflate(getLayoutInflater()); setContentView(binding.getRoot()); // 现在可以通过binding对象访问布局中的视图元素了 binding.textView.setText("Hello World!"); } // 对于Fragment private FragmentMainBinding binding; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { binding = FragmentMainBinding.inflate(inflater, container, false); View rootView = binding.getRoot(); // 现在可以通过binding对象访问布局中的视图元素了 binding.textView.setText("Hello World!"); return rootView; } ``` 通过使用视图绑定,你可以直接使用布局文件中定义的视图元素,而无需手动调用findViewById方法。这样可以提高代码的可读性和开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值