Android Studio 中Button控件的问题

目前在参考《第一行代码Android 第二版》
看到书中 第2.2.4节 在活动中使用Toast
其中我在写码Button的时候我的AS会报错
图片说明

附MainActivity.kt的代码
package com.example.myapplication

import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.view.View
import android.widget.Button
import android.widget.Toast

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.first_layout);
        Button button_1 = (Button) findViewById(R.id.button_1);
        button1 .setOnClickListener(new View.onClickListener) {
            @Override
            public void onClick(View v){
                Toast.makeText(MainActivity.this,"You Clcke Button 1",Toast.LENGTH_SHORT).show();
                        }

            };
    }
}

谢谢@王能指出代码没贴出来 此上为问题代码图片说明

4个回答

你在使用kotlin环境,请使用Kotlin语法,郭霖代码里的是Java代码

val button_1:Button;

dingdegao
北斗星_And 回复Torrely: 别一直下一步下一步,到configure的时候停一下,看一下language是不是Java,现在默认都是kotlin
3 个月之前 回复
dingdegao
北斗星_And 回复Torrely: 创建Android项目的时候,在Configure your project时,language 选择Java.
3 个月之前 回复
u010469910
Torrely 那我该怎么让他默认是java代码呢?
3 个月之前 回复

同步修正:
你建的是kotlin文件(以.kt结尾),把文件改成java文件就行了。

直接删掉然后右键创建java文件再用java语法写个MainActivity就行了

要想默认是java,彻底删除kotlin的依赖就行了:
1.打开根目录的build.gradle,Ctrl+F搜索“kotlin”关键字,删除整行
2.打开app的build.gradle,Ctrl+F搜索“kotlin”关键字,删除整行
3.重新sync+ReBuild项目,解决对应kotlin的报错即可

但kotlin是主流,再过3年估计就没java的事了

weimingjue
王能 回复Torrely: 如何删除kotlin也加了
3 个月之前 回复
u010469910
Torrely 好的 我试试 成功了采纳好评
3 个月之前 回复
weimingjue
王能 回复Torrely: 已修正回复
3 个月之前 回复
weimingjue
王能 回复Torrely: 文件创建错了
3 个月之前 回复
u010469910
Torrely 代码已补齐 就是图中的一片红色
3 个月之前 回复
u010469910
Torrely 没用我已经设置了自动import 或者是手动都一样还是红的红
3 个月之前 回复
u010469910
Torrely 不是很懂里面的内容
3 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Android,linearlayout中的button控件点击无效
初学者,在一个support.v4.widget.DrawerLayout中放了个linearlayout,又在里面放了两个button,发现按钮的点击事件触发不了,(我用的android:onclick="click"),请问有方法吗 <android.support.v4.widget.DrawerLayout android:id="@+id/drawer_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" android:background="@null" android:orientation="vertical"> <Button android:id="@+id/button4" android:layout_width="70dp" android:layout_height="70dp" android:onClick="open_door" android:background="@null" android:drawableTop="@drawable/home_icon" android:text="门禁" android:textSize="15dp" /> <Button android:id="@+id/button8" android:layout_width="70dp" android:layout_height="70dp" android:onClick="pay_tax" android:background="@null" android:drawableTop="@drawable/telephone_bill_icon" android:text="话费" android:textSize="15dp" /> </LinearLayout> </android.support.v4.widget.DrawerLayout>
Android studio布局中的button在真机中不显示,求解原因
![图片说明](https://img-ask.csdn.net/upload/201704/22/1492862089_931637.png) 这是布局,然后在真机中少了button,其他布局控件都有
android studio自定义滑动控件时,使用 ObjectAnimator.ofFloat滑动后,为什么getRight()值不变
android studio自定义滑动空间时,使用 ObjectAnimator.ofFloat滑动后,getRight()值不变 代码大概如下: ``` <FrameLayout android:layout_width="match_parent" android:layout_height="match_parent"> <Button android:stateListAnimator="@null" android:layout_gravity="right" android:text="删除" android:gravity="center" android:id="@+id/delete" android:layout_width="30dp" android:layout_height="30dp"/> <com.example.myapplication.TestView //自定义控件 android:background="@color/colorAccent" android:layout_width="match_parent" android:layout_height="30dp"> </com.example.myapplication.TestView> </FrameLayout> ``` 空间重写代码 ``` public class TestView extends LinearLayout { public TestView(Context context){ super(context); } public TestView(Context context, AttributeSet attrs){ super(context,attrs); } public TestView(Context context, AttributeSet attrs, int defStyleAttr){ super(context,attrs,defStyleAttr); } int lastX; int lastY; int offsetX; int startX; int startY; int itemwidth; int buttonWidth; int flag=1; ViewGroup viewGroup; @Override public boolean onTouchEvent(MotionEvent event) { int x = (int) event.getX(); int y = (int) event.getY(); switch ( event.getAction()){ case MotionEvent.ACTION_DOWN: Log.d("TestView", "ACTION_DOWN: "); flag =1; lastX=x; lastY=y; startX=getRight(); itemwidth=getWidth(); viewGroup=(ViewGroup) getParent(); buttonWidth=viewGroup.getChildAt(0).getWidth(); break; case MotionEvent.ACTION_MOVE: Log.d("TestView", "ACTION_MOVE: "); offsetX=lastX-x; if (offsetX>0) { layout((getLeft()-offsetX),getTop(),(getRight()-offsetX),getBottom()); } break; case MotionEvent.ACTION_UP: Log.d("TestView", "ACTION_UP: "); Log.d("TestView", "*****back star"); Log.d("TestView", "1*****getRight ="+String.valueOf(getRight())+"getLeft"+ String.valueOf(getLeft())); ObjectAnimator.ofFloat(this,"translationX",0, (itemwidth-getRight())).setDuration(300).start(); Log.d("TestView", "2*****getRight ="+String.valueOf(getRight())+"getLeft"+ String.valueOf(getLeft())); break; } return true; } } ``` 这个功能是让控件可以左滑,然后放手的时候动画的形式回到屏幕右边(x方向值为1440),拖动控件到x=1317,然后调用 ObjectAnimator.ofFloat,控件屏幕上显示回到右边了,但getRight()得到的数值和调用前得到的数值一样,为1317而不是1440,为什么会这样呢? ``` 2019-07-09 12:41:46.123 11400-11400/com.example.myapplication D/TestView: 1*****getRight =1317getLeft-123 2019-07-09 12:41:46.124 11400-11400/com.example.myapplication D/TestView: 2*****getRight =1317getLeft-123 ```
android studio关于checkbox无法解析文件的问题
选择checkbox时,会出现如图所示,invalid drawable tag vector(无效的可绘制标记向量),无法解析xml文件 ![图片说明](https://img-ask.csdn.net/upload/201603/09/1457491634_577111.png) 但是当我选择API21(包括以上的)则不出现该错误,这是为什么呢?求大神~能解决的话,感激不尽~ 布局文件代码如下(请忽略排版,只是试一下checkbox控件~): ``` <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <Button android:text="test" android:id="@+id/btn1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/btn1" /> <CheckBox android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="保存用户名和密码" android:id="@+id/cb_check" android:onClick="true" android:layout_toRightOf="@+id/btn1" /> <EditText android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/btn1" android:hint="输入用户名" android:id="@+id/et1"/> </RelativeLayout> ```
Android Studio XML文件编辑代码变化问题
我在xml文件加入一个button控件 layout_width=''match_parent'' 如果打开右边的preview或者按了下面的text后 match_parent自动变成了344dp。怎么解决啊!老铁们![图片](https://img-ask.csdn.net/upload/201706/20/1497964391_114565.jpg)
android studioUI控件位置
![图片说明](https://img-ask.csdn.net/upload/201903/30/1553936810_574837.png) android studioUI控件位置全在左上角,该怎么解决 ``` <?xml version="1.0" encoding="utf-8"?> <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" app:layout_behavior="@string/appbar_scrolling_view_behavior" tools:context=".MainActivity" tools:layout_editor_absoluteY="56dp" tools:showIn="@layout/activity_main"> <TextView android:id="@+id/textView" android:layout_width="0dp" android:layout_height="35dp" android:layout_marginStart="78dp" android:layout_marginLeft="78dp" android:layout_marginEnd="20dp" android:layout_marginRight="20dp" android:gravity="center" android:text="用户名" android:textSize="20dp" app:layout_constraintBaseline_toBaselineOf="@+id/editText" app:layout_constraintEnd_toStartOf="@+id/editText" app:layout_constraintStart_toStartOf="parent" /> <TextView android:id="@+id/textView2" android:layout_width="0dp" android:layout_height="35dp" android:layout_marginStart="78dp" android:layout_marginLeft="78dp" android:layout_marginEnd="20dp" android:layout_marginRight="20dp" android:gravity="center" android:text="密码" android:textSize="20dp" app:layout_constraintBaseline_toBaselineOf="@+id/editText2" app:layout_constraintEnd_toStartOf="@+id/editText2" app:layout_constraintStart_toStartOf="parent" /> <Button android:id="@+id/button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="登录" app:layout_constraintBaseline_toBaselineOf="@+id/button2" app:layout_constraintEnd_toEndOf="@+id/textView2" /> <Button android:id="@+id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="46dp" android:layout_marginEnd="21dp" android:layout_marginRight="21dp" android:text="注册" app:layout_constraintEnd_toEndOf="@+id/editText2" app:layout_constraintTop_toBottomOf="@+id/editText2" /> <EditText android:id="@+id/editText" android:layout_width="0dp" android:layout_height="35dp" android:layout_marginTop="144dp" android:layout_marginEnd="67dp" android:layout_marginRight="67dp" android:ems="10" android:inputType="textPersonName" android:text="" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toEndOf="@+id/textView" app:layout_constraintTop_toTopOf="parent" /> <EditText android:id="@+id/editText2" android:layout_width="0dp" android:layout_height="35dp" android:layout_marginTop="70dp" android:layout_marginEnd="67dp" android:layout_marginRight="67dp" android:ems="10" android:inputType="numberPassword" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toEndOf="@+id/textView2" app:layout_constraintTop_toBottomOf="@+id/editText" /> </android.support.constraint.ConstraintLayout> ```
为什么在android studio权限管理的地方已经添加了拨号权限,然而在运行时仍然出现闪退现象?
# 源代码: ``` import android.content.Intent; import android.net.Uri; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widget.Toast; public class MainActivity extends AppCompatActivity { private EditText et_number; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //【1】找到我们关心的控件edittext button et_number =(EditText) findViewById(R.id.editText1); //[2]找到按钮 Button btn_call=(Button)findViewById(R.id.button1); //[3]给button按钮设置一个点击事件 btn_call.setOnClickListener(new MyClickListener()); } //定义一个类去实现按钮需要的接口类型 private class MyClickListener implements OnClickListener { @Override public void onClick(View v){ //【4】获取edittext的文本内容 String number=et_number.getText().toString().trim(); if("".equals(number)){ /** * context上下文 */ Toast.makeText(MainActivity.this,"number不能为空",Toast.LENGTH_LONG).show(); return; } //【5】进行拨打电话,意图Intent Intent intent=new Intent();//创建一个意图对象 //【5.1】设置动作 intent.setAction(Intent.ACTION_CALL); //【5.2】设置要拨打的数据 // uri:统一资源标识符自己定义的路径,想代表什么就代表什么 // url:统一资源定位符 www.baidu.com intent.setData(Uri.parse("tel:"+number)); //【6】开启意图 startActivity(intent); } } } ``` 如代码所示,我想实现一个调用android打电话的功能,然而在开始拨打的时候却总是停止运行,权限也都已经添加了,如下图: ![图片说明](https://img-ask.csdn.net/upload/201905/22/1558525288_986077.png) 模拟器运行如图: ![图片说明](https://img-ask.csdn.net/upload/201905/22/1558525387_937990.png) 求大佬给个解决方法
Android自定义控件中为Button设置自定义监听器出现空指针。
Android自定义TopBar中给ImageButton设置自定义点击监听器,当点击ImageButton时在listener处出现NullPointerException。 会出错的地方我在后面写了//TODO 。 请问为什么会出现listener没有被实例化的情况? 还有为什么在MainActivity中使用findViewById实例化TopBar也会出现不能实例化控件的情况? IDE : Android Studio ; Compile Sdk Version : API 23 ; Build Tool Version : 23.0.1 ; Min Sdk Version : API 15 ; Target Sdk Version : API 19 ; 部分代码: #MainActivity.java ``` public class MainActivity extends AppCompatActivity { private TopBar topBar; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // topBar = (TopBar) findViewById(R.id.topBar); //TODO 这样无法实例化topBar ??? topBar = new TopBar(getApplicationContext(), null); if (topBar == null) { Toast.makeText(MainActivity.this, "NULL", Toast.LENGTH_SHORT).show(); } topBar.setOnTopBarClickListener(new TopBar.OnClickListener() { @Override public void onLeftButtonClick() { Toast.makeText(MainActivity.this, "Left", Toast.LENGTH_SHORT).show(); } @Override public void onRightButtonClick() { Toast.makeText(MainActivity.this, "Right", Toast.LENGTH_SHORT).show(); } }); } } ``` #TopBar.java ``` public class TopBar extends RelativeLayout { private ImageButton ibtLeft; private ImageButton ibtRight; private TextView tvTitle; private OnClickListener listener; public interface OnClickListener { void onLeftButtonClick(); void onRightButtonClick(); } public void setOnTopBarClickListener(OnClickListener listener) { this.listener = listener; } public TopBar(Context context, AttributeSet attrs) { super(context); LayoutInflater.from(context).inflate(R.layout.layout_top_bar, this); ibtLeft = (ImageButton) findViewById(R.id.ibt_left); ibtRight = (ImageButton) findViewById(R.id.ibt_right); tvTitle = (TextView) findViewById(R.id.tv_title); ibtLeft.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Toast.makeText(getContext(), "leftButton", Toast.LENGTH_SHORT).show(); //Toast可以显示 // listener.onLeftButtonClick(); //TODO NullPointerException 为什么没有实例化listener? } }); ibtRight.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { listener.onRightButtonClick(); //TODO NullPointerException } }); } } ``` #logcat输出 ``` 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: FATAL EXCEPTION: main 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: java.lang.NullPointerException 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at com.vder.puzzlegame.ui.TopBar$2.onClick(TopBar.java:55) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at android.view.View.performClick(View.java:4204) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at android.view.View$PerformClick.run(View.java:17355) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at android.os.Handler.handleCallback(Handler.java:725) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:92) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at android.os.Looper.loop(Looper.java:137) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:5041) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at java.lang.reflect.Method.invokeNative(Native Method) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at java.lang.reflect.Method.invoke(Method.java:511) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 10-14 13:42:14.442 1366-1366/com.vder.puzzlegame E/AndroidRuntime: at dalvik.system.NativeStart.main(Native Method) ```
android studio运行报下列错误
1.貌似有问题的代码 package com.example.coolweather; import android.app.Fragment; import android.app.ProgressDialog; import android.os.Bundle; import android.support.annotation.NonNull; import android.support.annotation.Nullable; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.AdapterView; import android.widget.ArrayAdapter; import android.widget.Button; import android.widget.ListView; import android.widget.TextView; import android.widget.Toast; import com.example.coolweather.db.City; import com.example.coolweather.db.County; import com.example.coolweather.db.Province; import com.example.coolweather.util.HttpUtil; import com.example.coolweather.util.Utility; import org.litepal.crud.DataSupport; import java.io.IOException; import java.util.ArrayList; import java.util.List; import okhttp3.Call; import okhttp3.Callback; import okhttp3.Response; /** * Created by Airth on 2019/5/10. */ public class ChooseAreaFragment extends Fragment { public static final int LEVEL_PROVINCE=0; public static final int LEVEL_CITY=1; public static final int LEVEL_COUNTY=2; private ProgressDialog progressDialog; private TextView titleText; private Button backButton; private ListView listView; private ArrayAdapter<String> adapter; private List<String> dataList = new ArrayList<>(); private int currentLevel; //当前被选中的级别 private Province selectedProvince;//被选中的省份 private City selectedCity;//被选中的城市 private List<Province> provinceList;//省列表 private List<City> cityList;//市列表 private List<County> countyList ;//县列表 /*获取控件实例id*/ @Override public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { Log.d("ChooseAreaFragment","onCreateView"); View view = inflater.inflate(R.layout.choose_area,container,false); titleText = (TextView)view.findViewById(R.id.title_text); //获取标题栏文本id backButton = (Button) view.findViewById(R.id.back_button); //获取标题栏id listView = (ListView)view.findViewById(R.id.list_view); //获取Item列表id //获取ArrayAdapter对象 adapter =new ArrayAdapter<>(getContext(), android.R.layout.simple_list_item_1, dataList); listView.setAdapter(adapter);//设置并初始化适配器 return view;//将视图返回 } /*点击事件集合*/ @Override public void onActivityCreated(@Nullable Bundle savedInstanceState) { Log.d("ChooseAreaFragment","onActivityCreated"); super.onActivityCreated(savedInstanceState); //列表任意一栏被点击,则... listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { Log.d("ChooseAreaFragment","列表被点了的..."); if (currentLevel == LEVEL_PROVINCE){ //当前选中的级别为省份时 selectedProvince = provinceList.get(position); //当前点击为选中状态 queryCities();//查询市的方法 } else if (currentLevel == LEVEL_CITY){ selectedCity = cityList.get(position); queryCounties(); } } }); backButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (currentLevel == LEVEL_COUNTY){ queryCities(); } else if (currentLevel == LEVEL_CITY){ queryProvinces(); } } }); queryProvinces(); } private void queryCities() { titleText.setText(selectedProvince.getProvinceName()); //设置市的标题内容 backButton.setVisibility(View.VISIBLE); //设置返回按钮可见 //查询被选中的省份城市的市区 cityList = DataSupport.where("provinceid=?",String.valueOf(selectedProvince. getId())).find(City.class); Log.d("ChooseAreaFragment","市级"); if (cityList.size()>0){ //如果省列表不为空,则... dataList.clear(); for (City city:cityList){ //遍历每一份省的市级城市 dataList.add(city.getCityName()); //添加到数据列表中 } adapter.notifyDataSetChanged();//通知适配器数据更新了 listView.setSelection(0); currentLevel = LEVEL_CITY; } else{ int provinceCode = selectedProvince.getProvinceCode(); //获取被选取省级代码 String address = "http://guolin.tech/api/china/"+provinceCode;//获取被选取地区的网络地址 Log.d("ChooseAreaFragment","准备在网络中获取地址信息"); queryFromServer(address,"city"); // 在网络中查询 } } /*根据传入的地址和类型从服务器查询省市县数据*/ private void queryFromServer(String adress, final String type) { showProgressDialog(); // 发送一条网络请求 HttpUtil.sendOKHttpRequest(adress, new Callback() { //请求加载失败 @Override public void onFailure(Call call, IOException e) { //通过runOnUiThread方法回到主线程逻辑 getActivity().runOnUiThread(new Runnable() { @Override public void run() { closeProgressDialog(); Toast.makeText(getContext(),"加载失败",Toast.LENGTH_SHORT).show(); } }); } @Override public void onResponse(Call call, Response response) throws IOException { Log.d("ChooseAreaFragment","加载地区信息..."); String responseText = response.body().string(); boolean result = false; if ("province".equals(type)){ result = Utility.handleProvinceResponse(responseText); } else if ("city".equals(type)){ result = Utility.handleCityResponse(responseText,selectedProvince.getId()); } else if ("county".equals(type)){ result = Utility.handleCountyResponse(responseText, selectedCity.getId()); } if (result) { getActivity().runOnUiThread(new Runnable() { @Override public void run() { Log.d("ChooseAreaFragment","开启线程更新UI"); closeProgressDialog(); if ("province".equals(type)){ queryProvinces(); } else if ("city".equals(type)){ queryCities(); } else if ("county".equals(type)){ queryCounties(); } } }); } if ("city".equals(type)){ result = Utility.handleProvinceResponse(responseText); } if ("county".equals(type)){ result = Utility.handleProvinceResponse(responseText); } } }); } /*显示进度对话框*/ private void showProgressDialog() { if (progressDialog==null){ progressDialog = new ProgressDialog(getActivity()); progressDialog.setMessage("正在加载..."); progressDialog.setCanceledOnTouchOutside(false); } progressDialog.show(); } private void queryCounties() { titleText.setText(selectedCity.getCityName()); backButton.setVisibility(View.VISIBLE); countyList = DataSupport.where("cityid = ?", String.valueOf(selectedCity.getId())).find(County.class); if (countyList.size()>0){ dataList.clear(); for (County county:countyList){ dataList.add(county.getCountyName()); } adapter.notifyDataSetChanged(); listView.setSelection(0); currentLevel=LEVEL_COUNTY; } else { int provinceCode = selectedProvince.getProvinceCode(); int cityCode = selectedCity.getCityCode(); String address = "http://guolin.tech/api/china/"+provinceCode+"/"+cityCode; queryFromServer(address,"county"); } } /*全国所有的省,优先查询数据库,如果没有再去服务器查询*/ private void queryProvinces() { titleText.setText("中国"); Log.d("ChooseAreaFragment","查询省中..."); backButton.setVisibility(View.GONE); provinceList = DataSupport.findAll(Province.class); if (provinceList.size()>0){ dataList.clear(); for (Province province:provinceList){ dataList.add(province.getProvinceName()); } adapter.notifyDataSetChanged(); listView.setSelection(0); currentLevel = LEVEL_PROVINCE; } else { Log.d("ChooseAreaFragment","服务器查询省中..."); String address = "http://guolin.tech/api/china"; queryFromServer(address,"province"); } } private void closeProgressDialog() { if (progressDialog!=null){ progressDialog.dismiss(); } } } 2.这是报错日志 ![图片说明](https://img-ask.csdn.net/upload/201905/10/1557481080_879893.png)
菜鸟求问!在andriod studio中如何使button大小与背景图片大小一致
没有添加背景图片的话,布局能够正常显示,但是增加背景图片再运行就把整个图片都显出来了,导致覆盖了。那么如何使大小与控件大小一致呢?![图片说明](https://img-ask.csdn.net/upload/201703/29/1490782722_38352.png) 这是我的代码,我刚开始学 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@drawable/title_bg" > <Button android:id="@+id/title_back" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:layout_margin="5dp" android:background="@drawable/back_bg" android:text="Back"/> <TextView android:id="@+id/title_text" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_gravity="center" android:layout_weight="1" android:gravity="center" android:text="Title Text" android:textColor="#fff" android:textSize="24sp"/> <Button android:id="@+id/title_edit" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:layout_margin="5dp" android:background="@drawable/edit_bg" android:text="Edit" android:textColor="#fff"/> </LinearLayout>
gridLayout 的子控件过大超出屏幕范围如何解决
想使用gridlayout实现计算器,发现子控件button会超出界面。改用其他布局可达成我想要的效果。但是如果不改用其他布局的话应该如何解决?? 尝试过给子控件button加上: android:layout_gravity="fill_vertical" 无效!! 以下为xml代码和效果图 ![图片说明](https://img-ask.csdn.net/upload/201902/15/1550213011_172173.jpg) ![图片说明](https://img-ask.csdn.net/upload/201902/15/1550213021_740307.jpg) 能明显看到3,6,9的按键超出父控件了一部分
androidstudio不小心把页面的控件给删除了,不能手动添加button了
![图片说明](https://img-ask.csdn.net/upload/201803/21/1521592322_739000.png) 这里面什么都没了,怎么还原
Android学习surfaceView遇到问题。可能很简单,希望有人指点迷津
我这几天用surfaceView来做视频播放的时候,file文件读取是没有问题的,但是在之后setDataSource()和.prepare()这两个方法的其中一个(抱歉,我实在不能确定问题到底出在这两个中的哪一个)抛出了IO异常。具体代码如下,我都做注释 package com.example.zyc.surfaceview; import android.media.MediaPlayer; import android.os.Environment; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.Surface; import android.view.SurfaceView; import android.view.View; import android.widget.Button; import android.widget.Toast; import java.io.File; import java.io.IOException; public class MainActivity extends AppCompatActivity { private MediaPlayer mediaPlayer; private SurfaceView surfaceView; private File file; private Button playButton; private Button pauseButton; private Button stopButton; private boolean isPlay; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //实现各种控件 mediaPlayer = new MediaPlayer(); surfaceView = (SurfaceView)findViewById(R.id.surfaceView1); playButton = (Button)findViewById(R.id.play); pauseButton = (Button)findViewById(R.id.pause); stopButton = (Button)findViewById(R.id.stop); //初始化一些变量 isPlay = false; file = new File(Environment.getExternalStorageDirectory().getPath()+"/ss.mp4"); pauseButton.setEnabled(false); //用来检查file是否读取正确 if(file.exists()){ Toast.makeText(MainActivity.this,"文件已经被获取 文件长度为"+file.length(),Toast.LENGTH_LONG).show(); }else{ Toast.makeText(MainActivity.this,"文件没有获得",Toast.LENGTH_LONG).show(); } //实现三个按钮的方法 playButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { mediaPlayer.reset(); //重置MediaPlay对象 try { mediaPlayer.setDataSource(file.getAbsolutePath()); //读取视频文件地址 mediaPlayer.prepare(); //预加载视频 mediaPlayer.setDisplay(surfaceView.getHolder()); //将视频画面输出到surface上 mediaPlayer.start(); //开始播放 pauseButton.setText("暂停"); //pause此时为暂停 pauseButton.setEnabled(true); //pause按钮此时可用 isPlay = true; }catch (IOException e){ Toast.makeText(MainActivity.this,"发生错误",Toast.LENGTH_LONG).show(); } } }); pauseButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (isPlay == true) { pauseButton.setText("继续"); mediaPlayer.pause(); isPlay = false; } else { mediaPlayer.start(); pauseButton.setText("暂停"); isPlay = true; } } }); stopButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if(isPlay==true){ mediaPlayer.stop(); Toast.makeText(MainActivity.this,"已停止",Toast.LENGTH_LONG).show(); pauseButton.setEnabled(false); } } }); } } 用的android studio,三星真机模拟 运行后的截图,(我还没点播放) ![图片说明](https://img-ask.csdn.net/upload/201602/14/1455463294_362010.png) 可以看到,文件长度。说明file的没有问题的 但是点击播放以后 ![图片说明](https://img-ask.csdn.net/upload/201602/14/1455463407_548795.png) 实在是不明白这怎么能错,其他人貌似也没有我这毛病啊
android开发,界面突然颜色错乱
本人大四学生,做一个Android app作为毕业设计,边学边做,不知道哪里出了问题 在一次调试后,整个app在xml设置的颜色,会在app启动一段时间后突然变成透明的 java代码设置的颜色和动态生成的控件颜色没有受到影响 我的手机是vivo,android8.1.0 -----------------------------补充-------------------------------------- 这个问题时出现在我向主界面的一个fragment添加了一个横向的RecyclerView后出现的,如果去掉这个RecyclerView就不会有问题 这个RecyclerView是装填的cardview ![图片说明](https://img-ask.csdn.net/upload/201905/08/1557249528_291636.jpg)![图片说明](https://img-ask.csdn.net/upload/201905/08/1557249554_948870.jpg) 有大神知道这可能是什么原因导致的吗,救救孩子吧= = cardview代码item_game_card.xml ``` <?xml version="1.0" encoding="utf-8"?> <android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:fresco="http://schemas.android.com/apk/res-auto" android:id="@+id/game_card" android:layout_width="90dp" android:layout_height="180dp" android:layout_margin="@dimen/dp_10" android:background="@color/colorPrimary" app:cardBackgroundColor="@color/color_light_blue" app:cardCornerRadius="@dimen/dp_10"> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <lib.lhh.fiv.library.FrescoImageView android:id="@+id/card_game_icon" android:layout_width="60dp" android:layout_height="60dp" android:layout_gravity="center|top" android:layout_marginTop="15dp" fresco:actualImageScaleType="centerCrop" fresco:failureImage="@drawable/gamenicon" fresco:placeholderImage="@drawable/gamenicon" fresco:placeholderImageScaleType="centerCrop" /> <TextView android:id="@+id/card_game_name" android:layout_width="70dp" android:layout_height="wrap_content" android:layout_gravity="center|top" android:layout_marginTop="15dp" android:maxLines="1" android:text="GameName" android:textAlignment="center" android:textColor="@color/white" android:textSize="11sp" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toBottomOf="@+id/card_game_icon" /> <TextView android:id="@+id/card_game_size" android:layout_width="wrap_content" android:layout_height="15dp" android:layout_gravity="center|top" android:layout_marginTop="2dp" android:text="GameSize" android:textAlignment="center" android:textColor="@color/white" android:textSize="11sp" fresco:layout_constraintEnd_toEndOf="parent" fresco:layout_constraintStart_toStartOf="parent" fresco:layout_constraintTop_toBottomOf="@+id/card_game_icon" /> <FrameLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="@dimen/dp_10"> <Button android:id="@+id/card_download" android:layout_width="70dp" android:layout_height="30dp" android:layout_gravity="center" android:alpha="0.1" android:background="@drawable/buttontranslucent" android:textColor="@android:color/black" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toBottomOf="@+id/card_game_name" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:text="下载" android:textSize="12sp" app:layout_constraintBottom_toBottomOf="@+id/card_download" app:layout_constraintEnd_toEndOf="@+id/card_download" app:layout_constraintStart_toStartOf="@+id/card_download" app:layout_constraintTop_toTopOf="@+id/card_download" /> </FrameLayout> </LinearLayout> </android.support.v7.widget.CardView> ``` 控件绑定代码 ``` public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_main, container, false); loadingPage = view.findViewById(R.id.loading_page); cardRecyclerView = view.findViewById(R.id.card_recyclerview); new Handler().postDelayed(new Runnable() { @Override public void run() { loadingPage.removeAllViews(); loadingPage.setVisibility(View.GONE); } }, 3000); getServerData(10); colorLine = view.findViewById(R.id.color_line); getColor = view.findViewById(R.id.get_color); getColor.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { Toast toast = Toast.makeText(getActivity(),String.valueOf(((ColorDrawable)colorLine.getBackground().mutate()).getColor()),Toast.LENGTH_SHORT); toast.show(); } }); mBanner = view.findViewById(R.id.banner); Btn_User = view.findViewById(R.id.main_userBtn); Btn_User.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { Intent intent = new Intent(getActivity(), UserActivity.class); startActivity(intent); } }); searchBox = view.findViewById(R.id.btn_search); //为搜索框添加点击事件 searchBox.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { Intent intent = new Intent(getActivity(), SearchActivity.class); startActivity(intent); } }); FrameLayout.LayoutParams layoutParams = new FrameLayout.LayoutParams(FrameLayout.LayoutParams.MATCH_PARENT, ScreenUtil.getScreenWidth(this.getContext()) / 2); mBanner.setLayoutParams(layoutParams); //修改切换动画 //mBanner.setPageTransformer(Transformer.Default); initBanner(mBanner); initLocalImage(); return view; } ``` RecyclerView 数据装填代码 ``` public void initCardRecyclerViewData(List<SimpleGame> GameList){ //创建布局管理 LinearLayoutManager layoutManager = new LinearLayoutManager(getActivity()); layoutManager.setOrientation(LinearLayoutManager.HORIZONTAL); cardRecyclerView.setLayoutManager(layoutManager); mAdapter = new GameCardAdapter(R.layout.item_game_card, GameList); //设置重复执行动画 mAdapter.isFirstOnly(true); //设置分割线 mAdapter.setOnItemChildClickListener(this); mAdapter.setOnItemClickListener(this); cardRecyclerView.setAdapter(mAdapter); } ``` 适配器用的是CymChad的BaseRecyclerViewAdapterHelper
初学Android-为什么EditText传送文本后secondActivity里的跑马灯无法显示文本?
1. 想自己制作一个可以自由输入文本的跑马灯程序,但是在编辑后发现跳转后不会显示文本。 2. 这是第一个布局文件: ```<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <EditText android:id="@+id/et_wb" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="请在此处输入内容" android:selectAllOnFocus="true"/> <Button android:id="@+id/bn1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@id/et_wb" android:layout_alignParentRight="true" android:text="确认" android:onClick="sendMessage"/> </RelativeLayout> ``` 3.这是MainActivity ```package cn.yuan.gen.pmdtest; import android.content.Intent; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.widget.EditText; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } public void sendMessage(View view) { Intent intent = new Intent(this,SecondActivity.class); // 获取控件: EditText editText = (EditText)findViewById(R.id.et_wb); // 将EditText获取的内容赋值给message: String message = editText.getText().toString(); // 给messa取名并传递给SecondActivity: intent.putExtra("Edit_Message",message); // 启动意图: startActivity(intent); } } ``` 4.这是第二个布局文件:<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/RecMes" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="10dp" android:ellipsize="marquee" android:focusable="true" android:focusableInTouchMode="true" android:gravity="center" android:singleLine="true" android:textColor="#000000" android:textSize="200dp"/> </RelativeLayout> ``` ``` 5.这是secondActivity: package cn.yuan.gen.pmdtest; import android.content.Intent; import android.content.pm.ActivityInfo; import android.os.Bundle; import android.support.annotation.Nullable; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.TextView; public class SecondActivity extends AppCompatActivity implements View.OnClickListener {//实现点击事件的接口 private TextView RecMes;//声明一个文本视图对象; private boolean isPause = false;//跑马灯是否滚动; @Override protected void onCreate(@Nullable Bundle savedInstanceState) { setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE); super.onCreate(savedInstanceState); setContentView(R.layout.sencond_main); Intent intent = getIntent(); // 把传送进来的String类型的Message的值赋给新的变量message: String message = intent.getStringExtra("EXTRA_MESSAGE"); // 把布局文件中的文本框和textview链接起来: TextView textView = (TextView) findViewById(R.id.RecMes); // 在textview中显示出message: textView.setText(message); } @Override public void onClick(View v) { if (v.getId() == R.id.RecMes) {//设置点击文本事件 isPause = !isPause; if (isPause) { RecMes.setFocusable(false);//不允许获得焦点; RecMes.setFocusableInTouchMode(false);//不允许在触摸时获得焦点; } else { RecMes.setFocusable(true); RecMes.setFocusableInTouchMode(true); RecMes.requestFocus();//强制获得焦点,让跑马灯跑起来; } } } } ``` ``` ![图片说明](https://img-ask.csdn.net/upload/201904/20/1555719123_923821.png)
android秒表代码的注释速求
``` package com.example.yk; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.view.Menu; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.TextView; public class CreativeActivity extends Activity { private TextView minText; //分 private TextView secText; //秒 private Button start; //开始按钮 private Button stop; //停止按钮 private boolean isPaused = false; private String timeUsed; private int timeUsedInsec; private Handler uiHandle = new Handler(){ public void handleMessage(android.os.Message msg) { switch(msg.what){ case 1: if(!isPaused) { addTimeUsed();//添加 updateClockUI();//更新 } uiHandle.sendEmptyMessageDelayed(1, 1000);// break; default: break; } } }; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_creative); //获取界面的控件 minText = (TextView) findViewById(R.id.min); secText = (TextView) findViewById(R.id.sec); start = (Button) findViewById(R.id.start); stop = (Button) findViewById(R.id.stop); //为按钮Start注册监听器 start.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub uiHandle.removeMessages(1); startTime(); isPaused = false; } }); //为按钮stop注册监听器 stop.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub isPaused = true; timeUsedInsec = 0; } }); } @Override protected void onPause() { // TODO Auto-generated method stub super.onPause(); isPaused = true; } @Override protected void onResume() { // TODO Auto-generated method stub super.onResume(); isPaused = false; } private void startTime(){ uiHandle.sendEmptyMessageDelayed(1, 1000); } /** * 更新时间的显示 */ private void updateClockUI(){ minText.setText(getMin() + ":"); secText.setText(getSec()); } public void addTimeUsed(){ timeUsedInsec = timeUsedInsec + 1; timeUsed = this.getMin() + ":" + this.getSec(); } public CharSequence getMin(){ return String.valueOf(timeUsedInsec / 60); } public CharSequence getSec(){ int sec = timeUsedInsec % 60; return sec < 10? "0" + sec :String.valueOf(sec); } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.creative, menu); return true; } } ```
RecyclerView中点击item跳转到其他Activity并显示item内容如何实现?
适配器代码 ``` package com.example.uilayout.adapter; import android.support.v7.widget.RecyclerView; import android.view.View; import android.view.ViewGroup; import android.widget.ImageView; import android.widget.TextView; import android.widget.Toast; import com.example.uilayout.R; import com.example.uilayout.model.Msg; import java.util.List; /** * Created by 夏雨来 on 2018/11/20. */ public class MsgListAdapter extends RecyclerView.Adapter<MsgListAdapter.viewHolder> { private List<Msg> msgList; //1、创建构造函数 //构造函数参数是list的集合,他是rv直接的数据来源 //在做Adapter实例化的时候必须传入list的集合数据 public MsgListAdapter(List<Msg> msgList) { this.msgList = msgList; } //2、创建类ViewHolder(视图容器),承载的是条目中的控件 //做条目中控件的声明和绑定 class viewHolder extends RecyclerView.ViewHolder{ ImageView iv_head; TextView tv_friend; TextView tv_message; TextView tv_time; View itemView; public viewHolder(View itemView) { super(itemView); //itemView的值由一步一步传递过来的 this.itemView=itemView; iv_head=itemView.findViewById(R.id.iv_head); tv_friend=itemView.findViewById(R.id.tv_friend); tv_message=itemView.findViewById(R.id.tv_message); tv_time=itemView.findViewById(R.id.tv_time); } } //创建ViewHolder对象 // @Override public viewHolder onCreateViewHolder(ViewGroup viewGroup, int i) { View itemView = View.inflate(viewGroup.getContext(),R.layout.item_msglist,null); viewHolder holder=new viewHolder(itemView); return holder; } //给ViewHolder中的控件设置数据 @Override public void onBindViewHolder(final viewHolder viewHolder, final int i) { final Msg msg = msgList.get(i); viewHolder.iv_head.setImageResource(msg.getImage_head()); viewHolder.tv_friend.setText(msg.getFriend()); viewHolder.tv_message.setText(msg.getMessage()); viewHolder.tv_time.setText(msg.getTime()); //设置条目中的点击监听 viewHolder.itemView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { Toast.makeText(view.getContext(), "你想与" + msg.getFriend() + "聊天", Toast.LENGTH_SHORT).show(); // TextView friendView=view.findViewById(R.id.tv_friend); // Intent intent=new Intent(); // Intent intent=new Intent(mContext,ChatActivity.class); // intent.putExtra("friend",msg.getFriend().toString()); // mContext.startActivity(intent); } }); //设置条目中具体控件的点击监听 // viewHolder.iv_head.setOnClickListener(new View.OnClickListener() { // @Override // public void onClick(View view) { // Toast.makeText(view.getContext(), "你点击了"+msg.getFriend()+"头像", Toast.LENGTH_SHORT).show(); // } // }); } @Override public int getItemCount() { return msgList.size(); } } ``` Activity代码 ``` package com.example.uilayout.activity; import android.content.Context; import android.content.Intent; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.support.v7.widget.LinearLayoutManager; import android.support.v7.widget.RecyclerView; import android.view.MenuItem; import android.view.View; import android.widget.AdapterView; import android.widget.Button; import android.widget.EditText; import android.widget.ListView; import android.widget.SimpleAdapter; import android.widget.TextView; import com.example.uilayout.model.Msg; import com.example.uilayout.adapter.MsgListAdapter; import com.example.uilayout.R; import com.example.uilayout.utils.MySQLiteOpenHelper; import java.util.ArrayList; import java.util.List; public class MsgListActivity extends AppCompatActivity { RecyclerView rv; List<Msg> msgList = new ArrayList<>(); // TextView friend; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_msglist); rv = findViewById(R.id.rv); // friend =findViewById(R.id.tv_friend); //给rv设置线性布局 rv.setLayoutManager(new LinearLayoutManager(this)); //初始化List集合数据 // initList(msgList); initListFromDB(); //给rv设置适配器 rv.setAdapter(new MsgListAdapter(msgList)); // MySQLiteOpenHelper helper=new MySQLiteOpenHelper(this,"wechat",null,1); // SQLiteDatabase db=helper.getWritableDatabase(); } public void initListFromDB() { MySQLiteOpenHelper helper = new MySQLiteOpenHelper(this, "wechat", null, 1); SQLiteDatabase db = helper.getWritableDatabase(); Cursor cursor = db.query("msg", null, null, null, null, null, null); while (cursor.moveToNext()) { int headImageSrc = cursor.getInt(cursor.getColumnIndex("headImageSrc")); String friend = cursor.getString(cursor.getColumnIndex("friend")); String message = cursor.getString(cursor.getColumnIndex("message")); String time = cursor.getString(cursor.getColumnIndex("time")); Msg msg = new Msg(headImageSrc, friend, message, time); msgList.add(msg); } } } ``` 布局文件 ``` <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="10dp" android:descendantFocusability="blocksDescendants" > <ImageView android:id="@+id/iv_head" android:layout_width="60dp" android:layout_height="60dp" android:src="@drawable/a" android:layout_marginTop="5dp" android:layout_marginLeft="10dp" android:onClick="click" /> <TextView android:id="@+id/tv_friend" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="小张" android:textSize="20sp" android:textColor="#000" android:layout_toRightOf="@+id/iv_head" android:layout_marginLeft="10dp" android:layout_marginTop="10dp" android:onClick="click" /> <TextView android:id="@+id/tv_message" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="你在干嘛" android:textSize="15sp" android:lines="1" android:layout_alignLeft="@+id/tv_friend" android:layout_marginTop="40dp" android:onClick="click" /> <TextView android:id="@+id/tv_time" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="21:00" android:textSize="15sp" android:layout_alignTop="@+id/tv_friend" android:layout_alignParentRight="true" android:layout_marginRight="10dp" android:onClick="click" /> <View android:layout_width="match_parent" android:layout_height="1dp" android:background="#C0C0C0" android:layout_alignLeft="@+id/iv_head" android:layout_alignRight="@+id/tv_time" android:layout_marginTop="74dp" /> </RelativeLayout> ``` 未跳转时界面 ![未跳转时界面](https://img-ask.csdn.net/upload/201812/23/1545574749_907427.png) 效果,点击item跳转到另一个界面之后,界面显示与XX聊天,XX是由item中获取的 ![效果,点击item跳转到另一个界面之后,界面显示与XX聊天,XX是由item中获取的](https://img-ask.csdn.net/upload/201812/23/1545574974_525413.png)
运行报FATAL EXCEPTION: main。
编写郭霖第一行代码和风天气 1.错误日志信息 ![图片说明](https://img-ask.csdn.net/upload/201905/11/1557552409_155464.png) 2.碎片布局后台代码 package com.example.coolweather; import android.app.Fragment; import android.app.ProgressDialog; import android.os.Bundle; import android.support.annotation.NonNull; import android.support.annotation.Nullable; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.AdapterView; import android.widget.ArrayAdapter; import android.widget.Button; import android.widget.ListView; import android.widget.TextView; import android.widget.Toast; import com.example.coolweather.db.City; import com.example.coolweather.db.County; import com.example.coolweather.db.Province; import com.example.coolweather.util.HttpUtil; import com.example.coolweather.util.Utility; import org.litepal.crud.DataSupport; import java.io.IOException; import java.util.ArrayList; import java.util.List; import okhttp3.Call; import okhttp3.Callback; import okhttp3.Response; /** * Created by Airth on 2019/5/10. */ public class ChooseAreaFragment extends Fragment { public static final int LEVEL_PROVINCE=0; public static final int LEVEL_CITY=1; public static final int LEVEL_COUNTY=2; private ProgressDialog progressDialog; private TextView titleText; private Button backButton; private ListView listView; private ArrayAdapter<String> adapter; private List<String> dataList = new ArrayList<>(); private int currentLevel; //当前被选中的级别 private Province selectedProvince;//被选中的省份 private City selectedCity;//被选中的城市 private List<Province> provinceList;//省列表 private List<City> cityList;//市列表 private List<County> countyList ;//县列表 /*获取控件实例id*/ @Override public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { Log.d("ChooseAreaFragment","onCreateView"); View view = inflater.inflate(R.layout.choose_area,container,false); titleText = (TextView)view.findViewById(R.id.title_text); //获取标题栏文本id backButton = (Button) view.findViewById(R.id.back_button); //获取标题栏id listView = (ListView)view.findViewById(R.id.list_view); //获取Item列表id //获取ArrayAdapter对象 adapter =new ArrayAdapter<>(getContext(), android.R.layout.simple_list_item_1, dataList); listView.setAdapter(adapter);//设置并初始化适配器 return view;//将视图返回 } /*点击事件集合*/ @Override public void onActivityCreated(@Nullable Bundle savedInstanceState) { Log.d("ChooseAreaFragment","onActivityCreated"); super.onActivityCreated(savedInstanceState); //列表任意一栏被点击,则... listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { Log.d("ChooseAreaFragment","列表被点了的..."); if (currentLevel == LEVEL_PROVINCE){ //当前选中的级别为省份时 selectedProvince = provinceList.get(position); //当前点击为选中状态 queryCities();//查询市的方法 } else if (currentLevel == LEVEL_CITY){ selectedCity = cityList.get(position); queryCounties(); } } }); backButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (currentLevel == LEVEL_COUNTY){ queryCities(); } else if (currentLevel == LEVEL_CITY){ queryProvinces(); } } }); queryProvinces(); } private void queryCities() { titleText.setText(selectedProvince.getProvinceName()); //设置市的标题内容 backButton.setVisibility(View.VISIBLE); //设置返回按钮可见 //查询被选中的省份城市的市区 cityList = DataSupport.where("provinceid=?",String.valueOf(selectedProvince. getId())).find(City.class); Log.d("ChooseAreaFragment","市级"); if (cityList.size()>0){ //如果省列表不为空,则... dataList.clear(); for (City city:cityList){ //遍历每一份省的市级城市 dataList.add(city.getCityName()); //添加到数据列表中 } adapter.notifyDataSetChanged();//通知适配器数据更新了 listView.setSelection(0); currentLevel = LEVEL_CITY; } else{ int provinceCode = selectedProvince.getProvinceCode(); //获取被选取省级代码 String address = "http://guolin.tech/api/china/"+provinceCode;//获取被选取地区的网络地址 Log.d("ChooseAreaFragment","准备在网络中获取地址信息"); queryFromServer(address,"city"); // 在网络中查询 } } /*根据传入的地址和类型从服务器查询省市县数据*/ private void queryFromServer(String adress, final String type) { showProgressDialog(); // 发送一条网络请求 HttpUtil.sendOKHttpRequest(adress, new Callback() { //请求加载失败 @Override public void onFailure(Call call, IOException e) { //通过runOnUiThread方法回到主线程逻辑 getActivity().runOnUiThread(new Runnable() { @Override public void run() { closeProgressDialog(); Toast.makeText(getContext(),"加载失败",Toast.LENGTH_SHORT).show(); } }); } @Override public void onResponse(Call call, Response response) throws IOException { Log.d("ChooseAreaFragment","加载地区信息..."); String responseText = response.body().string(); boolean result = false; if ("province".equals(type)){ result = Utility.handleProvinceResponse(responseText); } else if ("city".equals(type)){ result = Utility.handleCityResponse(responseText,selectedProvince.getId()); } else if ("county".equals(type)){ result = Utility.handleCountyResponse(responseText, selectedCity.getId()); } if (result) { getActivity().runOnUiThread(new Runnable() { @Override public void run() { Log.d("ChooseAreaFragment","开启线程更新UI"); closeProgressDialog(); if ("province".equals(type)){ queryProvinces(); } else if ("city".equals(type)){ queryCities(); } else if ("county".equals(type)){ queryCounties(); } } }); } if ("city".equals(type)){ result = Utility.handleProvinceResponse(responseText); } if ("county".equals(type)){ result = Utility.handleProvinceResponse(responseText); } } }); } /*显示进度对话框*/ private void showProgressDialog() { if (progressDialog==null){ progressDialog = new ProgressDialog(getActivity()); progressDialog.setMessage("正在加载..."); progressDialog.setCanceledOnTouchOutside(false); } progressDialog.show(); } private void queryCounties() { titleText.setText(selectedCity.getCityName()); backButton.setVisibility(View.VISIBLE); countyList = DataSupport.where("cityid = ?", String.valueOf(selectedCity.getId())).find(County.class); if (countyList.size()>0){ dataList.clear(); for (County county:countyList){ dataList.add(county.getCountyName()); } adapter.notifyDataSetChanged(); listView.setSelection(0); currentLevel=LEVEL_COUNTY; } else { int provinceCode = selectedProvince.getProvinceCode(); int cityCode = selectedCity.getCityCode(); String address = "http://guolin.tech/api/china/"+provinceCode+"/"+cityCode; queryFromServer(address,"county"); } } /*全国所有的省,优先查询数据库,如果没有再去服务器查询*/ private void queryProvinces() { titleText.setText("中国"); Log.d("ChooseAreaFragment","查询省中..."); backButton.setVisibility(View.GONE); provinceList = DataSupport.findAll(Province.class); if (provinceList.size()>0){ dataList.clear(); for (Province province:provinceList){ dataList.add(province.getProvinceName()); } adapter.notifyDataSetChanged(); listView.setSelection(0); currentLevel = LEVEL_PROVINCE; } else { Log.d("ChooseAreaFragment","服务器查询省中..."); String address = "http://guolin.tech/api/china"; queryFromServer(address,"province"); } } private void closeProgressDialog() { if (progressDialog!=null){ progressDialog.dismiss(); } } }
activity传值,没传过去唉
怎么才能从activity中传gps的值到myservice中,我的gps数据传不过去,求大佬解答 ``` public class MainActivity extends Activity { //地图相关 Workspace mWorkspace; MapView mMapView; private static Map m_map; private ZoomControls m_zoom; private LocationManager gpsLocationManager; public static Location lastLocation = null; private static Navigation mNavigation; private static Track m_track; private ImageButton ib_loc; private int screenWidth; private int screenHeight; String rootPath = android.os.Environment.getExternalStorageDirectory ().getAbsolutePath (); //设置全局变量并初始化 Point2D curLocation = new Point2D ( ); Point2D point2d= new Point2D ( ); private static Point2D mPoint; //是否第一次定位,如果是第一次定位的话要将自己的位置显示在地图中间 boolean isFirstOpen = true; //轨迹相关 public static boolean m_EnableLocationService; private Button btn_recording,btn_stop; private Layers m_Layers; public static double mlocationY,mlocationX; private boolean m_ExitEnable = false; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate ( savedInstanceState ); power(); Environment.setLicensePath ( rootPath + "/SuperMap/license/" ); Environment.setTemporaryPath ( rootPath + "/SuperMap/temp/" ); Environment.setWebCacheDirectory ( rootPath + "/SuperMap/WebCache/" ); Environment.initialization ( this ); startMyLocationServerce (); // 隐藏标题栏 requestWindowFeature ( Window.FEATURE_NO_TITLE ); // 隐藏状态栏 getWindow ().setFlags ( WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN ); WindowManager manager = getWindowManager (); screenWidth = manager.getDefaultDisplay ().getWidth (); screenHeight = manager.getDefaultDisplay ().getHeight (); setContentView ( R.layout.activity_main ); //打开地图 openMap (); //获取地图控件 initView (); //定位监听 initLocationListener (); //第一次定位返回定位点 firstLocation (); initTrack (); } private void power() { List<String> permissionList = new ArrayList<> (); if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest. permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) { permissionList.add(Manifest.permission.ACCESS_FINE_LOCATION); } if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest. permission.READ_PHONE_STATE) != PackageManager.PERMISSION_GRANTED) { permissionList.add(Manifest.permission.READ_PHONE_STATE); } if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest. permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) { permissionList.add(Manifest.permission.WRITE_EXTERNAL_STORAGE); } if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest. permission.RECORD_AUDIO) != PackageManager.PERMISSION_GRANTED) { permissionList.add(Manifest.permission.RECORD_AUDIO); } if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest. permission.CAMERA) != PackageManager.PERMISSION_GRANTED) { permissionList.add(Manifest.permission.CAMERA); } if (!permissionList.isEmpty()) { String[] permissions = permissionList.toArray(new String[permissionList. size()]); ActivityCompat.requestPermissions(MainActivity.this, permissions, 1); } else { } } private void initView() { m_zoom = (ZoomControls)findViewById(R.id.zoomControls1); mMapView = (MapView)findViewById(R.id.mapView); m_zoom.setIsZoomInEnabled(true); m_zoom.setIsZoomOutEnabled(true); ib_loc = findViewById ( R.id.ib_loc ); btn_recording = findViewById ( R.id.btn_recording ); btn_stop = findViewById ( R.id.btn_stop ); //放大按钮 m_zoom.setOnZoomInClickListener(new View.OnClickListener(){ public void onClick(View v) { m_map.zoom(2); m_map.refresh(); } }); //缩小按钮 m_zoom.setOnZoomOutClickListener(new View.OnClickListener(){ public void onClick(View v) { m_map.zoom(0.5); m_map.refresh(); } }); //返回当前位置 ib_loc.setOnClickListener ( new View.OnClickListener () { @Override public void onClick(View v) { m_map.setCenter ( point2d ); m_map.refresh (); } } ); btn_recording.setOnClickListener ( new View.OnClickListener () { @Override public void onClick(View v) { track(); updateLocation (); } } ); btn_stop.setOnClickListener ( new View.OnClickListener () { @Override public void onClick(View v) { m_track.stopTrack (); m_EnableLocationService = false; } } ); m_map.refresh(); } private void firstLocation(){ MapControl mapControl = mMapView.getMapControl (); mapControl.zoomTo ( 1,50000 ); //设置地图缩放等级 TextView tv1; tv1 = findViewById ( R.id.tv1 ); if(lastLocation != null){ if(isFirstOpen){ m_map.setCenter ( point2d ); m_map.refresh (); } isFirstOpen = false; System.out.print ("======================" + point2d ); double la = lastLocation.getLatitude (); double lo = lastLocation.getLongitude (); //测试用,所获取的是第一次定位的信息 tv1.setText ( "维度:" + (la ) + "\n经度" + (lo )); } else { tv1.setText ( "无法获取地理信息" ); } } private void openMap() { // 打开工作空间 mWorkspace = new Workspace (); WorkspaceConnectionInfo info = new WorkspaceConnectionInfo (); info.setServer ( rootPath + "/HiShow/SuperMap/mapData/mqdemo.smwu" ); info.setType ( WorkspaceType.SMWU ); mWorkspace.open ( info ); mMapView = (MapView) findViewById ( R.id.mapView ); MapControl mapControl = mMapView.getMapControl (); m_map = mapControl.getMap (); m_map.setWorkspace ( mWorkspace ); String mapName = mWorkspace.getMaps ().get ( 0 ); m_map.open ( mapName ); m_map.refresh (); mNavigation = mapControl.getNavigation (); mNavigation.setEncryption ( new SuperMapPatent () ); mapControl.setMapParamChangedListener ( mapParameterChangedListener ); } //使用gps定位自己 private void initLocationListener() { gpsLocationManager = (LocationManager) this .getSystemService ( Context.LOCATION_SERVICE ); if (ActivityCompat.checkSelfPermission ( this, Manifest.permission.ACCESS_FINE_LOCATION ) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission ( this, Manifest.permission.ACCESS_COARSE_LOCATION ) != PackageManager.PERMISSION_GRANTED) { // TODO: Consider calling // ActivityCompat#requestPermissions // here to request the missing permissions, and then overriding // public void onRequestPermissionsResult(int requestCode, String[] permissions, // int[] grantResults) // to handle the case where the user grants the permission. See the documentation // for ActivityCompat#requestPermissions for more details. return; } lastLocation = gpsLocationManager .getLastKnownLocation ( LocationManager.GPS_PROVIDER ); gpsLocationManager.requestLocationUpdates ( LocationManager.GPS_PROVIDER, 1, 1, locationListener ); } //自定义gps定位自己的监听 private final LocationListener locationListener = new LocationListener () { //Provider的转态在可用、暂时不可用和无服务三个状态直接切换时触发此函数 public void onStatusChanged(String provider, int status, Bundle extras) { updateLocation (); } //Provider被enable时触发此函数,比如网路被打开 public void onProviderEnabled(String provider) { } //Provider被disable时触发此函数,比如网路被关闭 public void onProviderDisabled(String provider) { } //当坐标改变时触发函数 public void onLocationChanged(Location location) { lastLocation = location; updateLocation (); } }; private final MapParameterChangedListener mapParameterChangedListener = new MapParameterChangedListener () { @Override public void scaleChanged(double arg0) { updateLocation (); } @Override public void boundsChanged(Point2D arg0) { updateLocation (); } @Override public void angleChanged(double v) { } @Override public void sizeChanged(int i, int i1) { } }; @Override protected void onDestroy() { super.onDestroy (); gpsLocationManager.removeUpdates ( locationListener ); mMapView.getMapControl ().removeMapParamChangedListener ( mapParameterChangedListener ); } @Override protected void onResume() { super.onResume (); if (ActivityCompat.checkSelfPermission ( this, Manifest.permission.ACCESS_FINE_LOCATION ) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission ( this, Manifest.permission.ACCESS_COARSE_LOCATION ) != PackageManager.PERMISSION_GRANTED) { // TODO: Consider calling // ActivityCompat#requestPermissions // here to request the missing permissions, and then overriding // public void onRequestPermissionsResult(int requestCode, String[] permissions, // int[] grantResults) // to handle the case where the user grants the permission. See the documentation // for ActivityCompat#requestPermissions for more details. return; } // 设置监听器,自动更新的最小时间为间隔N秒(1秒为1*1000)或最小位移变化超过N米 gpsLocationManager.requestLocationUpdates ( LocationManager.GPS_PROVIDER, 1, 1, locationListener ); } @Override protected void onPause() { super.onPause (); // 取消注册监听 gpsLocationManager.removeUpdates ( locationListener ); } //更新本地经纬度数据 private void updateLocation() { if (lastLocation == null) { return; } // sp = getSharedPreferences("lastLocation", Context.MODE_PRIVATE); // String mSLocationx = sp.getString("latitude", "0.0"); // String mSLocationy = sp.getString("longitude", "0.0"); // Double mLocationx = Double.valueOf(mSLocationx); // Double mLocationy = Double.valueOf(mSLocationy); //地理位置纠偏 curLocation.setX ( lastLocation.getLongitude () + 0.0055 );//经度 curLocation.setY ( lastLocation.getLatitude () + 0.015 );//维度 //地理坐标与投影坐标的转换 PrjCoordSys Prj = m_map.getPrjCoordSys (); if (Prj.getType () != PrjCoordSysType.PCS_EARTH_LONGITUDE_LATITUDE) { Point2Ds points = new Point2Ds (); points.add ( curLocation ); PrjCoordSys desPrjCoorSys = new PrjCoordSys (); desPrjCoorSys.setType ( PrjCoordSysType.PCS_EARTH_LONGITUDE_LATITUDE ); CoordSysTranslator.convert ( points, desPrjCoorSys, Prj, new CoordSysTransParameter (), CoordSysTransMethod.MTH_GEOCENTRIC_TRANSLATION ); curLocation = points.getItem ( 0 ); mlocationY = curLocation.getY (); mlocationX = curLocation.getX (); //从控制台查看想X、Y的值 // System.out.println ( mlocationX ); // System.out.println(mlocationY); point2d.setX ( mlocationX ); point2d.setY ( mlocationY ); GeoPoint gpsgeoPoint = new GeoPoint (); gpsgeoPoint.setX ( mlocationX ); gpsgeoPoint.setY ( mlocationY ); addCallByName(gpsgeoPoint); } } private void addCallByName(GeoPoint gps){ mMapView.removeAllCallOut (); CallOut callout = new CallOut ( MainActivity.this ); callout.setStyle ( CalloutAlignment.CENTER ); callout.setCustomize ( true ); callout.setLocation ( gps.getX (), gps.getY () ); ImageView image = new ImageView ( MainActivity.this ); image.setBackgroundResource ( R.drawable.location ); callout.setContentView ( image ); mMapView.addCallout ( callout ); } public void startMyLocationServerce(){ new Thread(new Runnable() { @Override public void run() { Intent intentService = new Intent(); intentService.setAction ( "com.lcdx.supermap.myapplication.MyLocationService.START" ); //从3.1以后要注册动态广播 intentService.setClass(MainActivity.this, MyLocationService.class); startService(intentService); } }).start(); } private void initTrack(){ if (m_track != null){ // 设置用户传入GPS数据 m_track.setCustomLocation(true); // 设置距离间隔为3米 m_track.setDistanceInterval(3); // 设置时间间隔为1s m_track.setTimeInterval(20); // 设置匹配道路所在的数据集 m_track.setMatchDatasets(m_map.getWorkspace().getDatasources().get("road").getDatasets()); m_track.setCustomLocation(false); } } /** * 设置用于轨迹记录的GPS数据 * @param gpsData */ private static int count = 0; public static void setGpsData(LocationManagePlugin.GPSData gpsData){ if(m_track != null){ //创建point2d Point2D mPoint = mNavigation.encryptGPS ( gpsData.dLongitude,gpsData.dLatitude ); gpsData.dLongitude = mPoint.getX (); gpsData.dLatitude = mPoint.getX (); m_track.setCustomLocation ( false ); m_track.setGPSData ( gpsData ); count ++; } if(50 == count){ m_map.refresh (); count = 0; } } private void track() { System.out.println("================================6"); Datasource m_Datasource = m_map.getWorkspace().getDatasources().get("track"); System.out.println("================================7"); m_Layers = m_map.getLayers(); System.out.println("================================8"); // 创建数据集 DatasetVector dataset = m_track.createDataset(m_Datasource, "qwe"); System.out.println("================================9"); //设置数据集的投影信息 PrjCoordSys Prj = m_map.getPrjCoordSys(); if (Prj.getType() != PrjCoordSysType.PCS_EARTH_LONGITUDE_LATITUDE) { PrjCoordSys desPrjCoorSys = new PrjCoordSys(); desPrjCoorSys.setType(PrjCoordSysType.PCS_EARTH_LONGITUDE_LATITUDE); dataset.setPrjCoordSys(desPrjCoorSys); } //设置轨迹记录的数据集为datas m_track.setDataset(dataset); System.out.println("================================10"); //开始轨迹记录 m_track.startTrack(); System.out.println("================================11"); clearLayers(); System.out.println("================================12"); //添加在图层轨迹记录的点数据 m_Layers.add(dataset, true); System.out.println("================================13"); System.out.println(dataset + "****************************dataset"); m_EnableLocationService = false; System.out.println("================================14"); //刷新地图 m_map.refresh(); System.out.println("================================15"); //开启定位 updateLocation (); } /** * 清除除了底图以外的图层 */ private void clearLayers() { int count = m_Layers.getCount(); for (; count > 1; ) { m_Layers.remove(0); count = m_Layers.getCount(); } } } ``` public class MyLocationService extends Service { public static double mlocationY,mlocationX; public static double douX,douY; private LocationManagePlugin.GPSData gpsData = new LocationManagePlugin.GPSData (); private SharedPreferences sp; @Override public IBinder onBind(Intent intent) { return null; } @Override public void onCreate() { // TODO Auto-generated method stub System.out.println("onCreate"); super.onCreate(); } @Override public void onDestroy() { // TODO Auto-generated method stub System.out.println("onDestroy"); mHandler.removeCallbacks(mRunnable); super.onDestroy(); } @Override public int onStartCommand(Intent intent, int flags, int startId) { // TODO Auto-generated method stub mHandler.postDelayed(mRunnable, 400); System.out.println("onStartCommand" + flags + "__" + startId); return super.onStartCommand(intent, flags, startId); } Handler mHandler = new Handler (); Runnable mRunnable = new Runnable () { @Override public void run() { if (MainActivity.m_EnableLocationService) { initGpsData(); MainActivity.setGpsData ( gpsData ); } mHandler.postDelayed(mRunnable, 400); } }; private void initGpsData(){ douX = MainActivity.lastLocation.getLongitude (); douY = MainActivity.lastLocation.getLatitude (); gpsData.dLatitude = mlocationY; gpsData.dLongitude = mlocationX; System.out.println("=========我的Y"+mlocationY); System.out.println("=========我的X"+mlocationX); } } ``` ```
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、PDF搜索网站推荐 对于大部
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Vue + Spring Boot 项目实战(十四):用户认证方案与完善的访问拦截
本篇文章主要讲解 token、session 等用户认证方案的区别并分析常见误区,以及如何通过前后端的配合实现完善的访问拦截,为下一步权限控制的实现打下基础。
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入  假设现有4个人
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
写在前面: 我是 扬帆向海,这个昵称来源于我的名字以及女朋友的名字。我热爱技术、热爱开源、热爱编程。技术是开源的、知识是共享的。 这博客是对自己学习的一点点总结及记录,如果您对 Java、算法 感兴趣,可以关注我的动态,我们一起学习。 用知识改变命运,让我们的家人过上更好的生活。 目录一、杨辉三角的介绍二、杨辉三角的算法思想三、代码实现1.第一种写法2.第二种写法 一、杨辉三角的介绍 百度
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
SQL-小白最佳入门sql查询一
一 说明 如果是初学者,建议去网上寻找安装Mysql的文章安装,以及使用navicat连接数据库,以后的示例基本是使用mysql数据库管理系统; 二 准备前提 需要建立一张学生表,列分别是id,名称,年龄,学生信息;本示例中文章篇幅原因SQL注释略; 建表语句: CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // dosho
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,
程序员:我终于知道post和get的区别
IT界知名的程序员曾说:对于那些月薪三万以下,自称IT工程师的码农们,其实我们从来没有把他们归为我们IT工程师的队伍。他们虽然总是以IT工程师自居,但只是他们一厢情愿罢了。 此话一出,不知激起了多少(码农)程序员的愤怒,却又无可奈何,于是码农问程序员。 码农:你知道get和post请求到底有什么区别? 程序员:你看这篇就知道了。 码农:你月薪三万了? 程序员:嗯。 码农:你是怎么做到的? 程序员:
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
      11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员
Android 9.0系统新特性,对刘海屏设备进行适配
其实Android 9.0系统已经是去年推出的“老”系统了,这个系统中新增了一个比较重要的特性,就是对刘海屏设备进行了支持。一直以来我也都有打算针对这个新特性好好地写一篇文章,但是为什么直到拖到了Android 10.0系统都发布了才开始写这篇文章呢?当然,一是因为我这段时间确实比较忙,今年几乎绝大部分的业余时间都放到写新书上了。但是最主要的原因并不是这个,而是因为刘海屏设备的适配存在一定的特殊性
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI 算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下
日均350000亿接入量,腾讯TubeMQ性能超过Kafka
整理 | 夕颜出品 | AI科技大本营(ID:rgznai100) 【导读】近日,腾讯开源动作不断,相继开源了分布式消息中间件TubeMQ,基于最主流的 OpenJDK8开发的
8年经验面试官详解 Java 面试秘诀
    作者 | 胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。   Java程序员准备和投递简历的实
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车? 某胡同口的煎饼摊一年能卖出多少个煎饼? 深圳有多少个产品经理? 一辆公交车里能装下多少个乒乓球? 一
相关热词 c# 输入ip c# 乱码 报表 c#选择结构应用基本算法 c# 收到udp包后回包 c#oracle 头文件 c# 序列化对象 自定义 c# tcp 心跳 c# ice连接服务端 c# md5 解密 c# 文字导航控件
立即提问