app直播源码,图片根据手指位置移动

app直播源码,图片根据手指位置移动实现的相关代码

页面布局

用于存放图片的容器(帧布局)

 

1
<?xml version="1.0" encoding="utf-8"?><br><FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"<br>  android:id="@+id/FrameLayout1"<br>  android:layout_width="match_parent"<br>  android:layout_height="match_parent"><br></FrameLayout>

 

继承自View的自定义组件类

 

1
LogoView.cs<br>using Android.Content;<br>using Android.Graphics;<br>using Android.Views;<br>namespace android_by_csharp<br>{<br>    public class LogoView : View<br>    {<br>        public float BitmapX;<br>        public float BitmapY;<br>        public LogoView(Context context) : base(context)<br>        {<br>            // 初始化图形要出现的坐标位置<br>            BitmapX = 0;<br>            BitmapY = 0;<br>        }<br>        // 重写OnDraw方法<br>        protected override void OnDraw(Canvas canvas)<br>        {<br>            base.OnDraw(canvas); <br>            // 画笔<br>            var paint = new Paint();<br>            // 生成位图对象<br>            var bitmap = BitmapFactory.DecodeResource(Resources, Resource.Drawable.mini_logo);<br>            if (bitmap == null) return;<br>            // 绘制位图<br>            canvas.DrawBitmap(bitmap, BitmapX - (float)bitmap.Width / 2, BitmapY - (float)bitmap.Height / 2, paint);<br>            // 判断图片是否回收,木有回收的话强制收回图片  <br>            if (!bitmap.IsRecycled)<br>                bitmap.Recycle();<br>        }<br>    }<br>}

 

 

在主类中引入自定义的组件类并想布局中添加图片

 

1
using Android.App;<br>using Android.OS;<br>using Android.Widget;<br>namespace android_by_csharp<br>{<br>    [Activity(Label = "@string/app_name", Theme = "@style/AppTheme", MainLauncher = true)]<br>    public class MainActivity : Activity<br>    {<br>        protected override void OnCreate(Bundle savedInstanceState)<br>        {<br>            base.OnCreate(savedInstanceState);<br>            // Set our view from the "main" layout resource<br>            SetContentView(Resource.Layout.activity_main);<br>            // 获取帧布局<br>            var frame = (FrameLayout)FindViewById(Resource.Id.FrameLayout1);<br>            var logo = new LogoView(this);<br>            logo.Touch += (s, e) =><br>            {<br>                if (e.Event == null) return;<br>                logo.BitmapX = e.Event.GetX();<br>                logo.BitmapY = e.Event.GetY();<br>                // 调用重绘方法<br>                logo.Invalidate();<br>            };<br>            // 添加logo图标<br>            frame?.AddView(logo);<br>        }<br>    }<br>}

 

以上就是app直播源码,图片根据手指位置移动实现的相关代码, 更多内容欢迎关注之后的文章

 

posted @   云豹科技-苏凌霄  阅读(71)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示