android listView 删除动画 当前Item 删了,但是动画总是从最后一行执行

点击ListView 的item中的控件,删除当前item时,想让它一动画的方式 消失,但是,点击删除时,item可以删除掉,但是动画总是执行的最后一行 求解、??

这是主要代码

@Override
public View getView(final int position, View convertView, ViewGroup parent) {
if (convertView == null) {
convertView = LayoutInflater.from(mActivity).inflate(R.layout.layout_dialog_item_detial, null);
holder = new ViewHolder();
holder.tv_time = (TextView) convertView.findViewById(R.id.tv_time);
holder.tv_score = (TextView) convertView.findViewById(R.id.tv_score);
holder.iv_delete = (ImageView) convertView.findViewById(R.id.iv_delete);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}

    DiagHistory dh = historyLists.get(position);
    holder.tv_time.setText(dh.getScanTime());
    holder.tv_score.setText(dh.getDiaScore());
    holder.iv_delete.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View v) {
            View itemView = (View) holder.iv_delete.getParent();
            removeListItem(itemView, position);
            SQLLiteService.getInstance(mActivity).deleteDialogHistory(holder.tv_time.getText().toString().trim());
        }
    });

    return convertView;
}

class ViewHolder {
    TextView tv_time, tv_score;
    ImageView iv_delete;
}

private void removeListItem(View rowView, final int positon) {
    final Animation animation = (Animation) AnimationUtils.loadAnimation(rowView.getContext(),
            R.anim.remove_dialog_list_item);
    animation.setAnimationListener(new AnimationListener() {
        public void onAnimationStart(Animation animation) {
        }

        public void onAnimationRepeat(Animation animation) {
        }

        public void onAnimationEnd(Animation animation) {
            historyLists.remove(positon);
            DialogItemDetailAdapter.this.notifyDataSetChanged();
            animation.cancel();
        }
    });
    rowView.startAnimation(animation);
}

5个回答

 View itemView = (View) holder.iv_delete.getParent();  //holder是个全局变量,最后指向界面显示的最后一条,所以你点随便哪一条,都是操作最后一条。这里需要当做参数传入到clicklisten中
            removeListItem(itemView, position);
重新定义OnClickListener
class SelfListener implements OnClickListener{
    private View itemView;
        private int positon;
        private String txt;
        public SelfListener(View itemView,int positon,String txt){
            this.itemView  = itemView;
                this.positon = positon;
                this.txt = txt;
        }
        @Override
        public void onClick(View v) {
            removeListItem(this.itemView, this.position);
            SQLLiteService.getInstance(mActivity).deleteDialogHistory(this.txt);
        }
}
//设置监听
holder.iv_delete.setOnClickListener(new SelfListener((View) holder.iv_delete.getParent(),position,holder.tv_time.getText().toString().trim()));
baidu_19694879
baidu_19694879 感谢!!!问题已解决。。。
大约 4 年之前 回复

1.removeListItem 这个传参,直接传convertView就可以;
2.另外你可以用 RecyclerView 代替ListView 这个默认就有动画
可以看我的博客,并且有demo
http://blog.csdn.net/q610098308/article/details/50173983

动画可以手动控制啊,当删除item的时候停住动画的播放,并且赋值为null

View itemView = (View) holder.iv_delete.getParent(); //holder是个全局变量,最后指向界面显示的最后一条,所以你点随便哪一条,都是操作最后一条。这里需要当做参数传入到clicklisten中
removeListItem(itemView, position);
重新定义OnClickListener
class SelfListener implements OnClickListener{
private View itemView;
private int positon;
private String txt;
public SelfListener(View itemView,int positon,String txt){
this.itemView = itemView;
this.positon = positon;
this.txt = txt;
}
@Override
public void onClick(View v) {
removeListItem(this.itemView, this.position);
SQLLiteService.getInstance(mActivity).deleteDialogHistory(this.txt);
}
}
//设置监听
holder.iv_delete.setOnClickListener(new SelfListener((View) holder.iv_delete.getParent(),position,holder.tv_time.getText().toString().trim()));

View itemView = (View) holder.iv_delete.getParent(); //holder是个全局变量,最后指向界面显示的最后一条,所以你点随便哪一条,都是操作最后一条。这里需要当做参数传入到clicklisten中
removeListItem(itemView, position);
重新定义OnClickListener
class SelfListener implements OnClickListener{
private View itemView;
private int positon;
private String txt;
public SelfListener(View itemView,int positon,String txt){
this.itemView = itemView;
this.positon = positon;
this.txt = txt;
}
@Override
public void onClick(View v) {
removeListItem(this.itemView, this.position);
SQLLiteService.getInstance(mActivity).deleteDialogHistory(this.txt);
}
}
//设置监听
holder.iv_delete.setOnClickListener(new SelfListener((View) holder.iv_delete.getParent(),position,holder.tv_time.getText().toString().trim()));

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Android 实现listview中的item部分的现实和隐藏

场景:istview中有n个item,每个item中有一个按钮(显示详细信息),当点击这个按钮是,item高度自动增加,并显示详细内容。

Android中,刷新ListView中的item导致ListView闪烁的解决方法

如题,因为下载列表使用ListView实现的,所以必须实时更新ListView中的数据。 我采用的是Service+BroadcastReceiver的搭配。更新数据 在Activity里面再用notifySetDataChange()的方法对ListView进行动态刷新 但是发现一个很严重的问题。刷新的时候ListView有明显的闪烁。 求解决方法

Android的ListeView滑动删除事件相关

Android中ListView的滑动删除,滑动可以实现,删除也可以实现。但是item删除过后,不可以自动回弹到初始位置。

RecyclerView子item点击跳转activity怎么加上过场动画?

在adapter中的onBindViewHolder( )方法中用了 ActivityOptionsCompat compat = ActivityOptionsCompat.makeSceneTransitionAnimation(mContext,view,"cover"); 运行后报错: java.lang.ClassCastException: android.app.Application cannot be cast to android.app.Activity

Android dialog上动画的问题

Activity上有ListView,点击ListView的Item会弹出dialog,点击dialog上的+号演示一个小球从+号飞到Activity底部的购物车的动画,想了好几天无法实现这个动画,要么这个动画是在dialog的后面,要么这个动画只能在dialog的范围内,求大神赐教!谢谢!! 下面贴我的代码 ``` public class MainActivity extends Activity implements OnClickListener { private Button bt; private TextView cart; private Button add; private ImageView photoImageView; private Dialog selectDialog; private int[] foodAddLocation = new int[2]; private int[] cartLocation = new int[2]; private ViewGroup animLayout;//动画层 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); bt = (Button) findViewById(R.id.bt); bt.setOnClickListener(this); cart = (TextView) findViewById(R.id.cart); } public void showSelectDialog() { View view = LayoutInflater.from(this).inflate(R.layout.dialog_view, null); ImageView close = (ImageView)view.findViewById(R.id.select_close); close.setOnClickListener(this); add = (Button)view.findViewById(R.id.add);//TODO add.setOnClickListener(this); TextView nameView = (TextView)view.findViewById(R.id.food_name); nameView.setText("哈哈哈"); photoImageView = (ImageView)view.findViewById(R.id.photo); photoImageView.setImageResource(R.drawable.ic_food_none); selectDialog = new Dialog(this, R.style.transparentFrameWindowStyle); selectDialog.setContentView(view, new LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT)); Window window = selectDialog.getWindow(); WindowManager windowManager = this.getWindowManager(); // 设置显示动画 WindowManager.LayoutParams wl = window.getAttributes(); wl.x = 0; wl.y = 0; // 设置显示位置 selectDialog.onWindowAttributesChanged(wl); Display display = windowManager.getDefaultDisplay(); WindowManager.LayoutParams lp = window.getAttributes(); lp.width = (int)(display.getWidth()*0.8); //设置宽度 selectDialog.getWindow().setAttributes(lp); // 设置点击外围关闭 selectDialog.setCanceledOnTouchOutside(true); selectDialog.show(); } private void addToCartAnimation(final ImageView ball, boolean isDialog) { animLayout = null; animLayout = createAnimLayout(isDialog); final View view = addViewToAnimLayout(animLayout, ball, foodAddLocation); cart.getLocationInWindow(cartLocation); // 计算位移 int endX = 0 - foodAddLocation[0] + cart.getWidth(); int endY = cartLocation[1] - foodAddLocation[1] - cart.getHeight()*3; TranslateAnimation translateAnimationX = new TranslateAnimation(-cart.getHeight(), endX+cart.getHeight(), 0, 0); translateAnimationX.setInterpolator(new LinearInterpolator()); translateAnimationX.setRepeatCount(0); translateAnimationX.setFillAfter(true); TranslateAnimation translateAnimationY = new TranslateAnimation(0, 0, -cart.getHeight()*3, endY-cart.getHeight()); translateAnimationY.setInterpolator(new AccelerateInterpolator()); translateAnimationY.setRepeatCount(0); translateAnimationY.setFillAfter(true); AnimationSet set = new AnimationSet(false); set.setFillAfter(false); set.addAnimation(translateAnimationY); set.addAnimation(translateAnimationX); set.setDuration(300); view.startAnimation(set); set.setAnimationListener(new AnimationListener() { @Override public void onAnimationStart(Animation animation) { ball.setVisibility(View.VISIBLE); } @Override public void onAnimationRepeat(Animation animation) { } @Override public void onAnimationEnd(Animation animation) { ball.setVisibility(View.GONE); } }); } private ViewGroup createAnimLayout(boolean isDialog) { Window window; if(isDialog){ window = selectDialog.getWindow(); }else{ window = this.getWindow(); } ViewGroup rootView = (ViewGroup) window.getDecorView(); LinearLayout animLayout = new LinearLayout(this); LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams( LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.MATCH_PARENT); animLayout.setLayoutParams(lp); animLayout.setId(Integer.MAX_VALUE); animLayout.setBackgroundResource(android.R.color.transparent); rootView.addView(animLayout); return animLayout; } private View addViewToAnimLayout(final ViewGroup animLayout, final View ball, int[] foodAddLocation) { int x = foodAddLocation[0]; int y = foodAddLocation[1]; LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams( LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT); lp.leftMargin = x; lp.topMargin = y; ball.setLayoutParams(lp); animLayout.addView(ball); return ball; } @Override public void onClick(View v) { switch(v.getId()){ case R.id.bt: showSelectDialog(); break; case R.id.add: add.getLocationInWindow(foodAddLocation); ImageView ball = new ImageView(this); ball.setImageResource(R.drawable.badge_ifaux); addToCartAnimation(ball, true); break; default: break; } } } ```

安卓 自定义listview+动画 下拉列表出现空指针 求解决

错误是: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.view.View.setScaleX(float)' on a null object reference 希望遇到过同样情况的大神给予指点 下面贴出我的代码 package net.bmvod.jukeboxv2; import android.animation.ValueAnimator; import android.annotation.SuppressLint; import android.content.Context; import android.content.res.TypedArray; import android.util.AttributeSet; import android.view.View; import android.widget.AbsListView; import android.widget.AdapterView; import android.widget.ListView; public class LvListView extends ListView implements AdapterView.OnItemClickListener { private boolean flag = true; private int lastPosition = 0 ; public LvListView(Context context) { this(context, null); } public LvListView(Context context, AttributeSet attrs) { this(context, attrs, 0); } public LvListView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); setOnItemClickListener(this); } public void startScaleAnimator(final View view, float start, float end) { final ValueAnimator animator = ValueAnimator.ofFloat(start, end); animator.setDuration(300); animator.start(); animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { float value = (Float) animation.getAnimatedValue(); view.setScaleX(value); view.setScaleY(0.4f + (0.6f * value)); } }); } @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { if (flag == true) { startScaleAnimator(view, 0.6f, 1.0f); lastPosition = position; flag = false; } else { if(lastPosition == position){ //startScaleAnimator(parent.getChildAt(lastPosition), 1.0f, 0.6f); lastPosition = position; }else{ startScaleAnimator(view, 0.6f, 1.0f); startScaleAnimator(parent.getChildAt(lastPosition), 1.0f, 0.6f); lastPosition = position; } } } } ``` ``` 自定义的listview和adapter实现item的动画效果 然后刚加载出来的时候是没有问题的 但是如果列表下拉列表再点击item程序就会崩溃 并报错在 animator.addUpdateListener里面 view.setScaleX(value);这一行有错误,不清楚什么原因,求大神帮忙指点一下

安卓 自定义listview+动画 下拉列表出现空指针 求解决

错误是: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.view.View.setScaleX(float)' on a null object reference 希望遇到过同样情况的大神给予指点 下面贴出我的代码 package net.bmvod.jukeboxv2; import android.animation.ValueAnimator; import android.annotation.SuppressLint; import android.content.Context; import android.content.res.TypedArray; import android.util.AttributeSet; import android.view.View; import android.widget.AbsListView; import android.widget.AdapterView; import android.widget.ListView; public class LvListView extends ListView implements AdapterView.OnItemClickListener { private boolean flag = true; private int lastPosition = 0 ; public LvListView(Context context) { this(context, null); } public LvListView(Context context, AttributeSet attrs) { this(context, attrs, 0); } public LvListView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); setOnItemClickListener(this); } public void startScaleAnimator(final View view, float start, float end) { final ValueAnimator animator = ValueAnimator.ofFloat(start, end); animator.setDuration(300); animator.start(); animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { float value = (Float) animation.getAnimatedValue(); view.setScaleX(value); view.setScaleY(0.4f + (0.6f * value)); } }); } @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { if (flag == true) { startScaleAnimator(view, 0.6f, 1.0f); lastPosition = position; flag = false; } else { if(lastPosition == position){ //startScaleAnimator(parent.getChildAt(lastPosition), 1.0f, 0.6f); lastPosition = position; }else{ startScaleAnimator(view, 0.6f, 1.0f); startScaleAnimator(parent.getChildAt(lastPosition), 1.0f, 0.6f); lastPosition = position; } } } } 自定义的listview和adapter实现item的动画效果 然后刚加载出来的时候是没有问题的 但是如果列表下拉列表再点击item程序就会崩溃 并报错在 animator.addUpdateListener里面 view.setScaleX(value);这一行有错误,不清楚什么原因,求大神帮忙指点一下

求教Fragment和ListView点击跳转

``` package gfxy.com.fragment_dahb; import android.app.Fragment; import android.os.Bundle; import android.support.annotation.Nullable; import android.view.KeyEvent; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.webkit.WebChromeClient; import android.webkit.WebSettings; import android.webkit.WebView; import android.webkit.WebViewClient; import android.widget.Button; import android.widget.EditText; import android.widget.Toast; public class Web extends Fragment { WebView we; EditText ed1; @Nullable @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { return inflater.inflate(R.layout.web,null); } @Override public void onActivityCreated(Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); getActivity().setContentView(R.layout.web); Button bu = (Button) getActivity().findViewById(R.id.webbut); ed1 = (EditText) getActivity().findViewById(R.id.webed); we = (WebView) getActivity().findViewById(R.id.webweb); WebSettings wes = we.getSettings(); wes.setJavaScriptEnabled(true); bu.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { setweb(); } }); we.setWebChromeClient(new WebChromeClient() { @Override public void onProgressChanged(WebView view, int newProgress) { if (newProgress == 100) { Toast.makeText(getActivity(), "网页加载完成", Toast.LENGTH_SHORT).show(); } else { Toast.makeText(getActivity(), "加载中", Toast.LENGTH_SHORT).show(); } } }); } public boolean onKeyDown(int keyCode, KeyEvent event) { if ((keyCode == KeyEvent.KEYCODE_BACK) && we.canGoBack()){ we.goBack(); return true; } return false; } public void setweb() { we.loadUrl("http://" + ed1.getText().toString().trim()); we.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; } }); } } ``` ``` package gfxy.com.fragment_dahb; import android.app.Fragment; import android.content.Context; import android.graphics.Color; import android.os.Bundle; import android.support.annotation.Nullable; import android.support.v4.widget.DrawerLayout; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.FrameLayout; import android.widget.LinearLayout; import android.widget.RadioGroup; import org.achartengine.ChartFactory; import org.achartengine.GraphicalView; import org.achartengine.model.CategorySeries; import org.achartengine.renderer.DefaultRenderer; import org.achartengine.renderer.SimpleSeriesRenderer; /** * Created by Administrator on 2016/4/18. */ public class bt extends Fragment { public void onActivityCreated(Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); FrameLayout sa = (FrameLayout) getActivity().findViewById(R.id.fm); sa.removeAllViews(); CategorySeries dataset=buildCategoryDataset("测试饼图"); GraphicalView graphicalView=ChartFactory.getPieChartView(getActivity(),dataset, renderer);//饼状图 sa.addView(graphicalView, new RadioGroup.LayoutParams(RadioGroup.LayoutParams.FILL_PARENT, RadioGroup.LayoutParams.FILL_PARENT)); } protected CategorySeries buildCategoryDataset(String title) { CategorySeries categorySeries = new CategorySeries(title); categorySeries.add("胜 ", 30); categorySeries.add("负", 20); categorySeries.add("平", 50); return categorySeries; } int[] colors={Color.BLUE,Color.GREEN,Color.MAGENTA,Color.RED}; DefaultRenderer renderer=buildCategoryRenderer(colors); protected DefaultRenderer buildCategoryRenderer(int[] colors) { DefaultRenderer renderer = new DefaultRenderer(); renderer.setLegendTextSize(20);//设置左下角表注的文字大小 //renderer.setZoomButtonsVisible(true);//设置显示放大缩小按钮 renderer.setZoomEnabled(false);//设置不允许放大缩小. renderer.setChartTitleTextSize(30);//设置图表标题的文字大小 renderer.setChartTitle("统计结果");//设置图表的标题 默认是居中顶部显示 renderer.setLabelsTextSize(20);//饼图上标记文字的字体大小 //renderer.setLabelsColor(Color.WHITE);//饼图上标记文字的颜色 renderer.setPanEnabled(false);//设置是否可以平移 //renderer.setDisplayValues(true);//是否显示值 renderer.setClickEnabled(true);//设置是否可以被点击 renderer.setMargins(new int[]{20, 30, 15, 0}); //margins - an array containing the margin size values, in this order: top, left, bottom, right for (int color : colors) { SimpleSeriesRenderer r = new SimpleSeriesRenderer(); r.setColor(color); renderer.addSeriesRenderer(r); } return renderer; } } ``` ``` <?xml version="1.0" encoding="utf-8"?> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical"> <LinearLayout android:layout_width="match_parent" android:layout_height="30dp" android:orientation="horizontal"> <TextView android:layout_width="match_parent" android:layout_height="match_parent" android:text="sadsd" android:textSize="25dp" android:gravity="center" android:background="#0f4"/> </LinearLayout> <android.support.v4.widget.DrawerLayout android:layout_width="match_parent" android:layout_height="match_parent"> <ListView android:id="@+id/lv" android:layout_width="240dp" android:layout_height="match_parent" android:layout_gravity="start" android:background="@null" android:choiceMode="singleChoice"> </ListView> <FrameLayout android:id="@+id/fm" android:layout_width="match_parent" android:layout_height="match_parent"> </FrameLayout> </android.support.v4.widget.DrawerLayout> </LinearLayout> ``` 我想把Web。和bt显示在framelayout里面,求教怎么做? 还有ListView的点击跳转事件之前用还没问题,也不知道干了什么,然后就不能进行跳转了 求解决?? ``` package gfxy.com.fragment_dahb; import android.app.Activity; import android.app.Fragment; import android.app.FragmentManager; import android.app.FragmentTransaction; import android.content.Intent; import android.os.Bundle; import android.support.v4.widget.DrawerLayout; import android.view.View; import android.widget.AdapterView; import android.widget.FrameLayout; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.SimpleAdapter; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; public class MainActivity extends Activity { private String[] name = new String[]{ "饼图","静态折线","动态折线","Web","逐帧动画","缩放,透明,旋转,平移" }; private FragmentManager fm; private FragmentTransaction ft; private FrameLayout fml; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); fml = (FrameLayout) findViewById(R.id.fm); ListView lv = (ListView)findViewById(R.id.lv); List<Map<String,Object>> list = new ArrayList<Map<String,Object>>(); for (int i=0;i<name.length;i++){ Map<String,Object> map = new HashMap<String,Object>(); map.put("name",name[i]); list.add(map); } lv.setAdapter(new SimpleAdapter(this,list,R.layout.content_main,new String[]{"name"},new int[]{R.id.text1})); // int wi = getWindowManager().getDefaultDisplay().getWidth();//获取手机宽度 // int hi = getWindowManager().getDefaultDisplay().getHeight();//获取手机高度 fm = getFragmentManager();//创建一个Fragment ft = fm.beginTransaction();//对Fragment进行添加,删除,替换 ft.replace(R.id.fm,new Fragment1()); ft.commit(); lv.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { if(position==0){ ft = fm.beginTransaction(); ft.replace(R.id.fm,new bt()); ft.commit(); } if(position==1){ ft = fm.beginTransaction(); ft.replace(R.id.fm,new Fragment1()); ft.commit(); } if(position==3){ ft = fm.beginTransaction(); ft.replace(R.id.fm,new Web()); ft.commit(); } } }); } } ```

listview 的监听事件中无法显示toast

package com.example; import java.util.ArrayList; import java.util.HashMap; import android.app.ListActivity; import android.os.Bundle; import android.util.Log; import android.view.View; import android.widget.AdapterView.OnItemClickListener; import android.widget.AdapterView; import android.widget.ArrayAdapter; import android.widget.ListView; import android.widget.SimpleAdapter; import android.widget.Toast; public class SimpleListViewWithTitle extends ListActivity { private static final String TAG="outputInformation"; private ListView listview; private String[] myTitle={"姓名:","性别:","年龄:","居住地:","邮箱:"}; private String[] myStr = {"MARES","男","25","北京","xuanyusong@gmail.com"}; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); ArrayList<HashMap<String,Object>> arrayList= new ArrayList<HashMap<String,Object>>(); for(int i=0;i<myTitle.length;i++){ HashMap<String,Object> hashMap= new HashMap<String,Object>(); hashMap.put("myTitle", myTitle[i]); hashMap.put("myStr", myStr[i]); arrayList.add(hashMap); } listview = getListView(); SimpleAdapter adapter = new SimpleAdapter(this,arrayList,android.R.layout.simple_expandable_list_item_2,new String[]{"myTitle","myStr"},new int[]{android.R.id.text1,android.R.id.text2}); setListAdapter(adapter); listview.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> adapterView, View view, int position,long id) { //System.out.println("您选择了" + myTitle[position]+":"+myStr[position]); Toast.makeText(SimpleListViewWithTitle.this,"您选择了" + myTitle[position]+":"+myStr[position],Toast.LENGTH_LONG).show(); Log.i(SimpleListViewWithTitle.TAG,"您选择了" + myTitle[position]+":"+myStr[position]); } }); setContentView(listview); } }

自定义listview点击监听时好时坏,不灵敏,是怎么回事啊

开始以为是设置的监听无效,后来发现是可以点击的,点击很不好用,偶尔才能点击到,请问是什么原因啊 package net.bmvod.jukeboxv2; import android.animation.ValueAnimator; import android.content.Context; import android.content.res.TypedArray; import android.util.AttributeSet; import android.util.Log; import android.view.MotionEvent; import android.view.View; import android.view.ViewGroup; import android.widget.AbsListView; import android.widget.AdapterView; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.Toast; /** * TODO: document your custom view class. */ public class LvListView extends ListView implements AbsListView.OnItemClickListener { /** * 显示在屏幕上多少个item */ private int showItemCount; /** * 每个item的高度 */ private int itemHeight; /** * 记录第一个显示的item */ /** * 从第几行执行动画 */ private int scaleFlagIndex = 0; /** * 是否到了最后一行 */ private boolean lastFlag = false; /** * 步骤 */ private int step = 0; /** * 步骤个数 */ private int stepCount; public LvListView(Context context) { this(context, null); } public LvListView(Context context, AttributeSet attrs) { this(context, attrs, 0); } /** * 构造方法中拿到自定义属性showViewCount,并设置滚动监听 * * @param context * @param attrs * @param defStyleAttr */ public LvListView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); //获取showViewCount TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.LvListView); showItemCount = typedArray.getInt(R.styleable.LvListView_showViewCount, 0); typedArray.recycle(); //设置一个滚动监听 // setOnScrollListener(this); setOnItemClickListener(this); } /** * 重写onLayout方法得到LvListview尺寸信息,并根据要显示的item个数计算出item高度并设置 * * @param changed * @param l * @param t * @param r * @param b */ @Override protected void onLayout(boolean changed, int l, int t, int r, int b) { super.onLayout(changed, l, t, r, b); if (changed) { itemHeight = this.getHeight() / showItemCount; for (int i = 0; i < getChildCount(); i++) { LinearLayout layout = (LinearLayout) getChildAt(i); LayoutParams layoutParams = new LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, itemHeight); layout.setLayoutParams(layoutParams); } stepCount = getAdapter().getCount(); } } /** * 禁用手指滑动 * * @param ev * @return */ /** * 设置滚动到指定item */ public void scrollToItem() { step++; if (step == stepCount) { step = 0; this.lastFlag = true; startScaleAnimator(getChildAt(scaleFlagIndex), 1.0f, 0.6f); this.smoothScrollToPositionFromTop(step, 0, 1000); } else { this.smoothScrollToPositionFromTop(step, 0, 500); } } /** * 缩放动画 * * @param view * @param start * @param end */ public void startScaleAnimator(final View view, float start, float end) { ValueAnimator animator = ValueAnimator.ofFloat(start, end); animator.setDuration(500); animator.start(); animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { float value = (float) animation.getAnimatedValue(); view.setScaleX(value); view.setScaleY(0.4f + (0.6f * value)); } }); } /* @Override public void onScrollStateChanged(AbsListView view, int scrollState) { Log.e("onScrollStateChanged", "scrollState--" + scrollState); if (scrollState == OnScrollListener.SCROLL_STATE_FLING) { if (!lastFlag) { startScaleAnimator(view.getChildAt(scaleFlagIndex), 1.0f, 0.6f); startScaleAnimator(view.getChildAt(scaleFlagIndex + 1), 0.6f, 1.0f); scaleFlagIndex = 2; } } else if (scrollState == OnScrollListener.SCROLL_STATE_IDLE && lastFlag) { this.lastFlag = false; //this.scaleFlag = true; scaleFlagIndex = 1; } } @Override public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) { Log.e("onScroll", "firstVisibleItem--" + firstVisibleItem); }*/ @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { System.out.println(position); switch (position) { case 0: startScaleAnimator(view, 0.6f, 1.0f); break; case 1: startScaleAnimator(view, 0.6f, 1.0f); break; case 2: startScaleAnimator(view, 0.6f, 1.0f); break; } } } ``` ``` 这是我的代码,是根据网上的例子改的,自定义listview的监听很不好,原来是跟本不可以点击然后我在列表的配置文件里面加了android:clickable="true" 之后的效果见识点20次能监听到一次那种效果,求解决

ListView界面混乱

根据需求需要在istView的Item被点击时给item的一个控件增加一个位移动画,并且动画结束后保持在动画结束时的位置,这些都ok,但是问题来了。点击第一条item动画结束后滑动listView到下面时有的Item也显示动画结束时的状态,求解

android-gif-drawable 加载太多的gif,有时gif动态图不动

我在项目里面加载使用android-gif-drawable,在一个listview里面,每个item都是一个gif动态图,比如动态表情,而且动态图重复率比较高,所以就做了**复用的机制**,但是发现加载太多,就会出现动态图不播放动画的情况,而且很频繁,求解?

如何获取GridView或ListView中的每一个view

如题,我想在gridview中的某一个指定的view中设置一个抖动的动画,但我发现如果是这样写: bankAdapter = new CustomGridAdapter(MainActivity.this, bankItems); bankGrid.setAdapter(bankAdapter); //动画 Animation shakeAnim = AnimationUtils.loadAnimation(MainActivity.this, R.anim.shake_x); //获取gridview中的第2个view RelativeLayout viewAnim =(RelativeLayout) bankGrid.getChildAt(2); if (viewAnim !=null) { ImageView img = (ImageView) viewAnim.findViewById(R.id.ItemImage) ; img.startAnimation(shakeAnim); } bankGrid.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { } 这时viewAnim的返回值是为null ,动画无法执行。 如果改为下面这样子: bankAdapter = new CustomGridAdapter(MainActivity.this, bankItems); bankGrid.setAdapter(bankAdapter); bankGrid.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { Animation shakeAnim = AnimationUtils.loadAnimation(MainActivity.this, R.anim.shake_x); RelativeLayout viewAnim =(RelativeLayout) bankGrid.getChildAt(2-bankGrid.getFirstVisiblePosition()); if (viewAnim !=null) { ImageView img = (ImageView) viewAnim.findViewById(R.id.ItemImage) ; img.startAnimation(shakeAnim); } } 那么在点击gridview中任意一项之后,第二个view就可以实现抖动的动画效果。 但是,我需要的是在没有点击gridview的情况下,即一进入应用,gridview中第二个view(按钮)就立即开始抖动,而不是监听点击事件后才执行。求问怎么才能实现??

急求....怎么实现每个ExpandableListView都为默认展开部分条目

首先 获取数据后的ExpandableListView 默认为全部关闭的,我要实现每个group都默认展开3条. 其余的都在点击之后展开........

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

实现简单的文件系统

实验内容: 通过对具体的文件存储空间的管理、文件的物理结构、目录结构和文件操作的实现,加深对文件系统内部功能和实现过程的理解。 要求: 1.在内存中开辟一个虚拟磁盘空间作为文件存储器,在其上实现一个简

MIPS单周期CPU-组成原理实验-华中科技大学

使用logisim布线完成的MIPS单周期CPU,可支持28条指令。跑马灯的代码已经装入了寄存器,可以直接开启时钟运行。

2019数学建模A题高压油管的压力控制 省一论文即代码

2019数学建模A题高压油管的压力控制省一完整论文即详细C++和Matlab代码,希望对同学们有所帮助

基于QT和OpenCV的五子棋实现源码

一个简单的五子棋应用,基于QT和OpenCV的实现源码,通过相邻棋子判断是否获胜,不包含人工智能算法,适合新手入门

Git 实用技巧

这几年越来越多的开发团队使用了Git,掌握Git的使用已经越来越重要,已经是一个开发者必备的一项技能;但很多人在刚开始学习Git的时候会遇到很多疑问,比如之前使用过SVN的开发者想不通Git提交代码为什么需要先commit然后再去push,而不是一条命令一次性搞定; 更多的开发者对Git已经入门,不过在遇到一些代码冲突、需要恢复Git代码时候就不知所措,这个时候哪些对 Git掌握得比较好的少数人,就像团队中的神一样,在队友遇到 Git 相关的问题的时候用各种流利的操作来帮助队友于水火。 我去年刚加入新团队,发现一些同事对Git的常规操作没太大问题,但对Git的理解还是比较生疏,比如说分支和分支之间的关联关系、合并代码时候的冲突解决、提交代码前未拉取新代码导致冲突问题的处理等,我在协助处理这些问题的时候也记录各种问题的解决办法,希望整理后通过教程帮助到更多对Git操作进阶的开发者。 本期教程学习方法分为“掌握基础——稳步进阶——熟悉协作”三个层次。从掌握基础的 Git的推送和拉取开始,以案例进行演示,分析每一个步骤的操作方式和原理,从理解Git 工具的操作到学会代码存储结构、演示不同场景下Git遇到问题的不同处理方案。循序渐进让同学们掌握Git工具在团队协作中的整体协作流程。 在教程中会通过大量案例进行分析,案例会模拟在工作中遇到的问题,从最基础的代码提交和拉取、代码冲突解决、代码仓库的数据维护、Git服务端搭建等。为了让同学们容易理解,对Git简单易懂,文章中详细记录了详细的操作步骤,提供大量演示截图和解析。在教程的最后部分,会从提升团队整体效率的角度对Git工具进行讲解,包括规范操作、Gitlab的搭建、钩子事件的应用等。 为了让同学们可以利用碎片化时间来灵活学习,在教程文章中大程度降低了上下文的依赖,让大家可以在工作之余进行学习与实战,并同时掌握里面涉及的Git不常见操作的相关知识,理解Git工具在工作遇到的问题解决思路和方法,相信一定会对大家的前端技能进阶大有帮助。

实用主义学Python(小白也容易上手的Python实用案例)

原价169,限时立减100元! 系统掌握Python核心语法16点,轻松应对工作中80%以上的Python使用场景! 69元=72讲+源码+社群答疑+讲师社群分享会&nbsp; 【哪些人适合学习这门课程?】 1)大学生,平时只学习了Python理论,并未接触Python实战问题; 2)对Python实用技能掌握薄弱的人,自动化、爬虫、数据分析能让你快速提高工作效率; 3)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; 4)想修炼更好的编程内功,优秀的工程师肯定不能只会一门语言,Python语言功能强大、使用高效、简单易学。 【超实用技能】 从零开始 自动生成工作周报 职场升级 豆瓣电影数据爬取 实用案例 奥运冠军数据分析 自动化办公:通过Python自动化分析Excel数据并自动操作Word文档,最终获得一份基于Excel表格的数据分析报告。 豆瓣电影爬虫:通过Python自动爬取豆瓣电影信息并将电影图片保存到本地。 奥运会数据分析实战 简介:通过Python分析120年间奥运会的数据,从不同角度入手分析,从而得出一些有趣的结论。 【超人气老师】 二两 中国人工智能协会高级会员 生成对抗神经网络研究者 《深入浅出生成对抗网络:原理剖析与TensorFlow实现》一书作者 阿里云大学云学院导师 前大型游戏公司后端工程师 【超丰富实用案例】 0)图片背景去除案例 1)自动生成工作周报案例 2)豆瓣电影数据爬取案例 3)奥运会数据分析案例 4)自动处理邮件案例 5)github信息爬取/更新提醒案例 6)B站百大UP信息爬取与分析案例 7)构建自己的论文网站案例

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

C/C++跨平台研发从基础到高阶实战系列套餐

一 专题从基础的C语言核心到c++ 和stl完成基础强化; 二 再到数据结构,设计模式完成专业计算机技能强化; 三 通过跨平台网络编程,linux编程,qt界面编程,mfc编程,windows编程,c++与lua联合编程来完成应用强化 四 最后通过基于ffmpeg的音视频播放器,直播推流,屏幕录像,

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

Python界面版学生管理系统

前不久上传了一个控制台版本的学生管理系统,这个是Python界面版学生管理系统,这个是使用pycharm开发的一个有界面的学生管理系统,基本的增删改查,里面又演示视频和完整代码,有需要的伙伴可以自行下

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

linux“开发工具三剑客”速成攻略

工欲善其事,必先利其器。Vim+Git+Makefile是Linux环境下嵌入式开发常用的工具。本专题主要面向初次接触Linux的新手,熟练掌握工作中常用的工具,在以后的学习和工作中提高效率。

JAVA初级工程师面试36问(完结)

第三十一问: 说一下线程中sleep()和wait()区别? 1 . sleep()是让正在执行的线程主动让出CPU,当时间到了,在回到自己的线程让程序运行。但是它并没有释放同步资源锁只是让出。 2.wait()是让当前线程暂时退让出同步资源锁,让其他线程来获取到这个同步资源在调用notify()方法,才会让其解除wait状态,再次参与抢资源。 3. sleep()方法可以在任何地方使用,而wait()只能在同步方法或同步块使用。 ...

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

我以为我对Mysql事务很熟,直到我遇到了阿里面试官

太惨了,面试又被吊打

智鼎(附答案).zip

并不是完整题库,但是有智鼎在线2019年9、10、11三个月的试题,有十七套以上题目,普通的网申行测题足以对付,可以在做题时自己总结一些规律,都不是很难

Visual Assist X 破解补丁

vs a's'sixt插件 支持vs2008-vs2019 亲测可以破解,希望可以帮助到大家

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

JavaWEB商城项目(包括数据库)

功能描述:包括用户的登录注册,以及个人资料的修改.商品的分类展示,详情,加入购物车,生成订单,到银行支付等!另外还有收货地址的和我的收藏等常用操作.环境(JDK 1.7 ,mysql 5.5,Ecli

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

一学即懂的计算机视觉(第一季)

图像处理和计算机视觉的课程大家已经看过很多,但总有“听不透”,“用不了”的感觉。课程致力于创建人人都能听的懂的计算机视觉,通过生动、细腻的讲解配合实战演练,让学生真正学懂、用会。 【超实用课程内容】 课程内容分为三篇,包括视觉系统构成,图像处理基础,特征提取与描述,运动跟踪,位姿估计,三维重构等内容。课程理论与实战结合,注重教学内容的可视化和工程实践,为人工智能视觉研发及算法工程师等相关高薪职位就业打下坚实基础。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/26281 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程2年有效观看时长,但是大家可以抓紧时间学习后一起讨论哦~ 【学员专享增值服务】 源码开放 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 下载方式:电脑登录https://edu.csdn.net/course/detail/26281,点击右下方课程资料、代码、课件等打包下载

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

课程主要面向嵌入式Linux初学者、工程师、学生 主要从一下几方面进行讲解: 1.linux学习路线、基本命令、高级命令 2.shell、vi及vim入门讲解 3.软件安装下载、NFS、Samba、FTP等服务器配置及使用

2019 Python开发者日-培训

本次活动将秉承“只讲技术,拒绝空谈”的理念,邀请十余位身处一线的Python技术专家,重点围绕Web开发、自动化运维、数据分析、人工智能等技术模块,分享真实生产环境中使用Python应对IT挑战的真知灼见。此外,针对不同层次的开发者,大会还安排了深度培训实操环节,为开发者们带来更多深度实战的机会。

快速入门Android开发 视频 教程 android studio

这是一门快速入门Android开发课程,顾名思义是让大家能快速入门Android开发。 学完能让你学会如下知识点: Android的发展历程 搭建Java开发环境 搭建Android开发环境 Android Studio基础使用方法 Android Studio创建项目 项目运行到模拟器 项目运行到真实手机 Android中常用控件 排查开发中的错误 Android中请求网络 常用Android开发命令 快速入门Gradle构建系统 项目实战:看美图 常用Android Studio使用技巧 项目签名打包 如何上架市场

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

4小时玩转微信小程序——基础入门与微信支付实战

这是一个门针对零基础学员学习微信小程序开发的视频教学课程。课程采用腾讯官方文档作为教程的唯一技术资料来源。杜绝网络上质量良莠不齐的资料给学员学习带来的障碍。 视频课程按照开发工具的下载、安装、使用、程序结构、视图层、逻辑层、微信小程序等几个部分组织课程,详细讲解整个小程序的开发过程

YOLOv3目标检测实战系列课程

《YOLOv3目标检测实战系列课程》旨在帮助大家掌握YOLOv3目标检测的训练、原理、源码与网络模型改进方法。 本课程的YOLOv3使用原作darknet(c语言编写),在Ubuntu系统上做项目演示。 本系列课程包括三门课: (1)《YOLOv3目标检测实战:训练自己的数据集》 包括:安装darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 (2)《YOLOv3目标检测:原理与源码解析》讲解YOLOv1、YOLOv2、YOLOv3的原理、程序流程并解析各层的源码。 (3)《YOLOv3目标检测:网络模型改进方法》讲解YOLOv3的改进方法,包括改进1:不显示指定类别目标的方法 (增加功能) ;改进2:合并BN层到卷积层 (加快推理速度) ; 改进3:使用GIoU指标和损失函数 (提高检测精度) ;改进4:tiny YOLOv3 (简化网络模型)并介绍 AlexeyAB/darknet项目。

Qt5 局域网通信软件(模仿QQ)

采用Qt5进行开发的局域网通信客户端+Server,界面模仿QQ的界面,聊天界面采用QWidget绘制的气泡!

Python数据清洗实战入门

本次课程主要以真实的电商数据为基础,通过Python详细的介绍了数据分析中的数据清洗阶段各种技巧和方法。

YOLOv3目标检测实战:训练自己的数据集

YOLOv3是一种基于深度学习的端到端实时目标检测方法,以速度快见长。本课程将手把手地教大家使用labelImg标注和使用YOLOv3训练自己的数据集。课程分为三个小项目:足球目标检测(单目标检测)、梅西目标检测(单目标检测)、足球和梅西同时目标检测(两目标检测)。 本课程的YOLOv3使用Darknet,在Ubuntu系统上做项目演示。包括:安装Darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 Darknet是使用C语言实现的轻型开源深度学习框架,依赖少,可移植性好,值得深入探究。 除本课程《YOLOv3目标检测实战:训练自己的数据集》外,本人推出了有关YOLOv3目标检测的系列课程,请持续关注该系列的其它课程视频,包括: 《YOLOv3目标检测实战:交通标志识别》 《YOLOv3目标检测:原理与源码解析》 《YOLOv3目标检测:网络模型改进方法》 敬请关注并选择学习!

Python可以这样学(第一季:Python内功修炼)

董付国系列教材《Python程序设计基础》、《Python程序设计(第2版)》、《Python可以这样学》配套视频,讲解Python 3.5.x和3.6.x语法、内置对象用法、选择与循环以及函数设计与使用、lambda表达式用法、字符串与正则表达式应用、面向对象编程、文本文件与二进制文件操作、目录操作与系统运维、异常处理结构。

相关热词 c#框体中的退出函数 c# 按钮透明背景 c# idl 混编出错 c#在位置0处没有任何行 c# 循环给数组插入数据 c# 多线程死锁的例子 c# 钉钉读取员工排班 c# label 不显示 c#裁剪影像 c#工作进程更新ui
立即提问