首页 文章 精选 留言 我的

精选列表

搜索[水平分库],共10033篇文章
优秀的个人博客,低调大师

Android开源:水平方向listview,HorizontalListView

用法: 与普通listview一样。 项目地址:https://github.com/dinocore1/DevsmartLib-Android 代码: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 package com.devsmart.android.ui; import java.util.LinkedList; import java.util.Queue; import android.content.Context; import android.database.DataSetObserver; import android.graphics.Rect; import android.util.AttributeSet; import android.view.GestureDetector; import android.view.GestureDetector.OnGestureListener; import android.view.MotionEvent; import android.view.View; import android.widget.AdapterView; import android.widget.ListAdapter; import android.widget.Scroller; public class HorizontalListView extends AdapterView<ListAdapter> { public boolean mAlwaysOverrideTouch = true ; protected ListAdapter mAdapter; private int mLeftViewIndex = - 1 ; private int mRightViewIndex = 0 ; protected int mCurrentX; protected int mNextX; private int mMaxX = Integer.MAX_VALUE; private int mDisplayOffset = 0 ; protected Scroller mScroller; private GestureDetector mGesture; private Queue<View> mRemovedViewQueue = new LinkedList<View>(); private OnItemSelectedListener mOnItemSelected; private OnItemClickListener mOnItemClicked; private OnItemLongClickListener mOnItemLongClicked; private boolean mDataChanged = false ; public HorizontalListView(Context context, AttributeSet attrs) { super (context, attrs); initView(); } private synchronized void initView() { mLeftViewIndex = - 1 ; mRightViewIndex = 0 ; mDisplayOffset = 0 ; mCurrentX = 0 ; mNextX = 0 ; mMaxX = Integer.MAX_VALUE; mScroller = new Scroller(getContext()); mGesture = new GestureDetector(getContext(), mOnGesture); } @Override public void setOnItemSelectedListener(AdapterView.OnItemSelectedListener listener) { mOnItemSelected = listener; } @Override public void setOnItemClickListener(AdapterView.OnItemClickListener listener){ mOnItemClicked = listener; } @Override public void setOnItemLongClickListener(AdapterView.OnItemLongClickListener listener) { mOnItemLongClicked = listener; } private DataSetObserver mDataObserver = new DataSetObserver() { @Override public void onChanged() { synchronized (HorizontalListView. this ){ mDataChanged = true ; } invalidate(); requestLayout(); } @Override public void onInvalidated() { reset(); invalidate(); requestLayout(); } }; @Override public ListAdapter getAdapter() { return mAdapter; } @Override public View getSelectedView() { //TODO: implement return null ; } @Override public void setAdapter(ListAdapter adapter) { if (mAdapter != null ) { mAdapter.unregisterDataSetObserver(mDataObserver); } mAdapter = adapter; mAdapter.registerDataSetObserver(mDataObserver); reset(); } private synchronized void reset(){ initView(); removeAllViewsInLayout(); requestLayout(); } @Override public void setSelection( int position) { //TODO: implement } private void addAndMeasureChild( final View child, int viewPos) { LayoutParams params = child.getLayoutParams(); if (params == null ) { params = new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT); } addViewInLayout(child, viewPos, params, true ); child.measure(MeasureSpec.makeMeasureSpec(getWidth(), MeasureSpec.AT_MOST), MeasureSpec.makeMeasureSpec(getHeight(), MeasureSpec.AT_MOST)); } @Override protected synchronized void onLayout( boolean changed, int left, int top, int right, int bottom) { super .onLayout(changed, left, top, right, bottom); if (mAdapter == null ){ return ; } if (mDataChanged){ int oldCurrentX = mCurrentX; initView(); removeAllViewsInLayout(); mNextX = oldCurrentX; mDataChanged = false ; } if (mScroller.computeScrollOffset()){ int scrollx = mScroller.getCurrX(); mNextX = scrollx; } if (mNextX <= 0 ){ mNextX = 0 ; mScroller.forceFinished( true ); } if (mNextX >= mMaxX) { mNextX = mMaxX; mScroller.forceFinished( true ); } int dx = mCurrentX - mNextX; removeNonVisibleItems(dx); fillList(dx); positionItems(dx); mCurrentX = mNextX; if (!mScroller.isFinished()){ post( new Runnable(){ @Override public void run() { requestLayout(); } }); } } private void fillList( final int dx) { int edge = 0 ; View child = getChildAt(getChildCount()- 1 ); if (child != null ) { edge = child.getRight(); } fillListRight(edge, dx); edge = 0 ; child = getChildAt( 0 ); if (child != null ) { edge = child.getLeft(); } fillListLeft(edge, dx); } private void fillListRight( int rightEdge, final int dx) { while (rightEdge + dx < getWidth() && mRightViewIndex < mAdapter.getCount()) { View child = mAdapter.getView(mRightViewIndex, mRemovedViewQueue.poll(), this ); addAndMeasureChild(child, - 1 ); rightEdge += child.getMeasuredWidth(); if (mRightViewIndex == mAdapter.getCount()- 1 ) { mMaxX = mCurrentX + rightEdge - getWidth(); } if (mMaxX < 0 ) { mMaxX = 0 ; } mRightViewIndex++; } } private void fillListLeft( int leftEdge, final int dx) { while (leftEdge + dx > 0 && mLeftViewIndex >= 0 ) { View child = mAdapter.getView(mLeftViewIndex, mRemovedViewQueue.poll(), this ); addAndMeasureChild(child, 0 ); leftEdge -= child.getMeasuredWidth(); mLeftViewIndex--; mDisplayOffset -= child.getMeasuredWidth(); } } private void removeNonVisibleItems( final int dx) { View child = getChildAt( 0 ); while (child != null && child.getRight() + dx <= 0 ) { mDisplayOffset += child.getMeasuredWidth(); mRemovedViewQueue.offer(child); removeViewInLayout(child); mLeftViewIndex++; child = getChildAt( 0 ); } child = getChildAt(getChildCount()- 1 ); while (child != null && child.getLeft() + dx >= getWidth()) { mRemovedViewQueue.offer(child); removeViewInLayout(child); mRightViewIndex--; child = getChildAt(getChildCount()- 1 ); } } private void positionItems( final int dx) { if (getChildCount() > 0 ){ mDisplayOffset += dx; int left = mDisplayOffset; for ( int i= 0 ;i<getChildCount();i++){ View child = getChildAt(i); int childWidth = child.getMeasuredWidth(); child.layout(left, 0 , left + childWidth, child.getMeasuredHeight()); left += childWidth + child.getPaddingRight(); } } } public synchronized void scrollTo( int x) { mScroller.startScroll(mNextX, 0 , x - mNextX, 0 ); requestLayout(); } @Override public boolean dispatchTouchEvent(MotionEvent ev) { boolean handled = super .dispatchTouchEvent(ev); handled |= mGesture.onTouchEvent(ev); return handled; } protected boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) { synchronized (HorizontalListView. this ){ mScroller.fling(mNextX, 0 , ( int )-velocityX, 0 , 0 , mMaxX, 0 , 0 ); } requestLayout(); return true ; } protected boolean onDown(MotionEvent e) { mScroller.forceFinished( true ); return true ; } private OnGestureListener mOnGesture = new GestureDetector.SimpleOnGestureListener() { @Override public boolean onDown(MotionEvent e) { return HorizontalListView. this .onDown(e); } @Override public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) { return HorizontalListView. this .onFling(e1, e2, velocityX, velocityY); } @Override public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) { synchronized (HorizontalListView. this ){ mNextX += ( int )distanceX; } requestLayout(); return true ; } @Override public boolean onSingleTapConfirmed(MotionEvent e) { for ( int i= 0 ;i<getChildCount();i++){ View child = getChildAt(i); if (isEventWithinView(e, child)) { if (mOnItemClicked != null ){ mOnItemClicked.onItemClick(HorizontalListView. this , child, mLeftViewIndex + 1 + i, mAdapter.getItemId( mLeftViewIndex + 1 + i )); } if (mOnItemSelected != null ){ mOnItemSelected.onItemSelected(HorizontalListView. this , child, mLeftViewIndex + 1 + i, mAdapter.getItemId( mLeftViewIndex + 1 + i )); } break ; } } return true ; } @Override public void onLongPress(MotionEvent e) { int childCount = getChildCount(); for ( int i = 0 ; i < childCount; i++) { View child = getChildAt(i); if (isEventWithinView(e, child)) { if (mOnItemLongClicked != null ) { mOnItemLongClicked.onItemLongClick(HorizontalListView. this , child, mLeftViewIndex + 1 + i, mAdapter.getItemId(mLeftViewIndex + 1 + i)); } break ; } } } private boolean isEventWithinView(MotionEvent e, View child) { Rect viewRect = new Rect(); int [] childPosition = new int [ 2 ]; child.getLocationOnScreen(childPosition); int left = childPosition[ 0 ]; int right = left + child.getWidth(); int top = childPosition[ 1 ]; int bottom = top + child.getHeight(); viewRect.set(left, top, right, bottom); return viewRect.contains(( int ) e.getRawX(), ( int ) e.getRawY()); } }; } 本文转自 glblong 51CTO博客,原文链接:http://blog.51cto.com/glblong/1307725,如需转载请自行联系原作者

优秀的个人博客,低调大师

android 图片水平反复平铺(repeat x)

《=用来反复显示的图 1.最简单方式 创建wave_repeat.xml <? xml version = "1.0" encoding = "utf-8" ?> < bitmap xmlns:android = "http://schemas.android.com/apk/res/android" android:src = "@drawable/wave" android:tileMode = "repeat" /> 在layout中使用 < View android:layout_width = "match_parent" android:layout_height = "wrap_content" android:background = "@drawable/wave_repeat" /> 这样的方式有一个问题。最后一张 反复 图片不一定是完整的图片可能仅仅是一部分 效果图:(左右两条竖线是后来加的) 2.可确保最后一张反复图片是完整的。就是几个完整的一样的图片X轴反复 Resources res = context .getResources(); Bitmap bitmap = BitmapFactory.decodeResource(res, R.drawable. wave ); holder. viewWave .setImageBitmap(BitmapHelper.createRepeater( screenWidth , bitmap)); //screenWidth为屏幕宽度(或显示图片的 imageview 宽度) BitmapHelper.java 中的方法 public static Bitmap createRepeater( int width, Bitmap src) { int count = (width + src.getWidth() - 1) / src.getWidth(); //计算出平铺填满所给width(宽度)最少须要的反复次数 Bitmap bitmap = Bitmap.createBitmap(src.getWidth()*count, src.getHeight(), Config. ARGB_8888 ); Canvas canvas = new Canvas(bitmap); for ( int idx = 0; idx < count; ++idx) { canvas.drawBitmap(src, idx * src.getWidth(), 0, null ); } return bitmap; } 在layout中设置imageview的scaleType为fitXY < ImageView android:id = "@+id/view_wave" android:layout_width = "match_parent" android:layout_height = "wrap_content" android:scaleType = "fitXY" /> 效果图: 本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/5087711.html,如需转载请自行联系原作者

优秀的个人博客,低调大师

android将图片和文字水平排列

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 <?xmlversion= "1.0" encoding= "utf-8" ?> <LinearLayoutxmlns:android= "http://schemas.android.com/apk/res/android" android:layout_width= "match_parent" android:layout_height= "wrap_content" android:orientation= "horizontal" android:gravity= "center" > <ImageView android:id= "@+id/imageView4_1_1" android:layout_width= "wrap_content" android:layout_height= "wrap_content" android:src= "@drawable/ic_launcher" /> <TextView android:id= "@+id/textView4_1_1" android:layout_width= "match_parent" android:layout_height= "wrap_content" android:text= "textView" /> </LinearLayout> android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:gravity="center" 本文转自 matengbing 51CTO博客,原文链接:http://blog.51cto.com/matengbing/1882230

资源下载

更多资源
腾讯云软件源

腾讯云软件源

为解决软件依赖安装时官方源访问速度慢的问题,腾讯云为一些软件搭建了缓存服务。您可以通过使用腾讯云软件源站来提升依赖包的安装速度。为了方便用户自由搭建服务架构,目前腾讯云软件源站支持公网访问和内网访问。

Spring

Spring

Spring框架(Spring Framework)是由Rod Johnson于2002年提出的开源Java企业级应用框架,旨在通过使用JavaBean替代传统EJB实现方式降低企业级编程开发的复杂性。该框架基于简单性、可测试性和松耦合性设计理念,提供核心容器、应用上下文、数据访问集成等模块,支持整合Hibernate、Struts等第三方框架,其适用范围不仅限于服务器端开发,绝大多数Java应用均可从中受益。

Rocky Linux

Rocky Linux

Rocky Linux(中文名:洛基)是由Gregory Kurtzer于2020年12月发起的企业级Linux发行版,作为CentOS稳定版停止维护后与RHEL(Red Hat Enterprise Linux)完全兼容的开源替代方案,由社区拥有并管理,支持x86_64、aarch64等架构。其通过重新编译RHEL源代码提供长期稳定性,采用模块化包装和SELinux安全架构,默认包含GNOME桌面环境及XFS文件系统,支持十年生命周期更新。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。

用户登录
用户注册