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直播源码,图片根据手指位置移动实现的相关代码, 更多内容欢迎关注之后的文章
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现