Drghezzi / app.py
Esmaeilkianii's picture
Update app.py
1e831d3 verified
import streamlit as st
import geemap
import pandas as pd
import ee
import folium
from streamlit_folium import st_folium
# تنظیمات احراز هویت Google Earth Engine
service_account = '[email protected]'
credentials = ee.ServiceAccountCredentials(service_account, 'ee-esmaeilkiani1387-1b2c5e812a1d.json')
ee.Initialize(credentials)
# تابع برای دریافت NDVI یا NDMI از Sentinel-2
def get_ndvi_ndmi_map(lat, lon, index='NDVI'):
# محدوده منطقه مورد نظر
point = ee.Geometry.Point([lon, lat])
area = point.buffer(5000) # بافر به شعاع 5 کیلومتر
# لایه Sentinel-2
collection = ee.ImageCollection('COPERNICUS/S2').filterBounds(area).filterDate('2023-01-01', '2023-12-31').sort('CLOUDY_PIXEL_PERCENTAGE').first()
# شاخص NDVI یا NDMI
if index == 'NDVI':
ndvi = collection.normalizedDifference(['B8', 'B4']).rename('NDVI')
vis_params = {'min': 0, 'max': 1, 'palette': ['blue', 'white', 'green']}
else:
ndmi = collection.normalizedDifference(['B8', 'B11']).rename('NDMI')
vis_params = {'min': -1, 'max': 1, 'palette': ['brown', 'white', 'blue']}
# نقشه ایجاد کنید
m = geemap.Map(center=[lat, lon], zoom=13)
if index == 'NDVI':
m.addLayer(ndvi, vis_params, 'NDVI')
else:
m.addLayer(ndmi, vis_params, 'NDMI')
return m
# بارگذاری اطلاعات مزرعه از CSV
def load_farm_data(csv_url):
df = pd.read_csv(csv_url)
return df
# برنامه اصلی
def main():
st.title("نمایش نقشه شاخص NDVI یا NDMI با Sentinel-2")
# دریافت نام مزرعه از کاربر
st.sidebar.header("ورودی کاربر")
farm_name = st.sidebar.text_input("نام مزرعه را وارد کنید:")
# انتخاب شاخص
index_option = st.sidebar.selectbox("شاخص مورد نظر:", ['NDVI', 'NDMI'])
# بارگذاری داده‌های مزارع
csv_url = 'https://huggingface.co./spaces/Esmaeilkianii/Drghezzi/raw/main/Farm_Details_Export.csv'
farm_data = load_farm_data(csv_url)
# پیدا کردن اطلاعات مزرعه بر اساس نام
if farm_name:
selected_farm = farm_data[farm_data['Farm'] == farm_name]
if not selected_farm.empty:
lat = selected_farm['Latitude'].values[0]
lon = selected_farm['Longitude'].values[0]
age = selected_farm['Age'].values[0]
variety = selected_farm['Variety'].values[0]
# نمایش اطلاعات مزرعه
st.write(f"مزرعه: {farm_name}, سن: {age} سال، واریته: {variety}")
# دریافت و نمایش نقشه با شاخص انتخابی
st.write(f"نقشه شاخص {index_option} برای مزرعه {farm_name}:")
map_ndvi_ndmi = get_ndvi_ndmi_map(lat, lon, index=index_option)
st_folium(map_ndvi_ndmi, width=700, height=500)
else:
st.write("مزرعه مورد نظر یافت نشد.")
else:
st.write("لطفاً نام مزرعه را وارد کنید.")
if __name__ == "__main__":
main()